A<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.cppe.ru/index.php?action=history&amp;feed=atom&amp;title=C%2FData_Structure_Algorithm%2FLink_List</id>
		<title>C/Data Structure Algorithm/Link List - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.cppe.ru/index.php?action=history&amp;feed=atom&amp;title=C%2FData_Structure_Algorithm%2FLink_List"/>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C/Data_Structure_Algorithm/Link_List&amp;action=history"/>
		<updated>2026-04-17T22:36:31Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.cppe.ru/index.php?title=C/Data_Structure_Algorithm/Link_List&amp;diff=230&amp;oldid=prev</id>
		<title> в 14:20, 25 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C/Data_Structure_Algorithm/Link_List&amp;diff=230&amp;oldid=prev"/>
				<updated>2010-05-25T14:20:56Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 14:20, 25 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://www.cppe.ru/index.php?title=C/Data_Structure_Algorithm/Link_List&amp;diff=231&amp;oldid=prev</id>
		<title>Admin: 1 версия:&amp;#32;Импорт контента...</title>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C/Data_Structure_Algorithm/Link_List&amp;diff=231&amp;oldid=prev"/>
				<updated>2010-05-25T10:22:28Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия: Импорт контента...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==illustrates the    use and maintenance of doubly linked lists==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;&lt;br /&gt;
/*&lt;br /&gt;
C: The Complete Reference, 4th Ed. (Paperback)&lt;br /&gt;
by Herbert Schildt&lt;br /&gt;
ISBN: 0072121246&lt;br /&gt;
Publisher: McGraw-Hill Osborne Media; 4 edition (April 26, 2000)&lt;br /&gt;
*/&lt;br /&gt;
/* A simple mailing list program that illustrates the&lt;br /&gt;
   use and maintenance of doubly linked lists.&lt;br /&gt;
*/&lt;br /&gt;
#include &amp;lt;stdio.h&amp;gt;&lt;br /&gt;
#include &amp;lt;stdlib.h&amp;gt;&lt;br /&gt;
#include &amp;lt;string.h&amp;gt;&lt;br /&gt;
struct address {&lt;br /&gt;
  char name[30];&lt;br /&gt;
  char street[40];&lt;br /&gt;
  char city[20];&lt;br /&gt;
  char state[3];&lt;br /&gt;
  char zip[11]; &lt;br /&gt;
  struct address *next;  /* pointer to next entry */&lt;br /&gt;
  struct address *prior;  /* pointer to previous record */&lt;br /&gt;
};&lt;br /&gt;
struct address *start;  /* pointer to first entry in list */&lt;br /&gt;
struct address *last;  /* pointer to last entry */&lt;br /&gt;
struct address *find(char *);&lt;br /&gt;
void enter(void), search(void), save(void);&lt;br /&gt;
void load(void), list(void);&lt;br /&gt;
void mldelete(struct address **, struct address **);&lt;br /&gt;
void dls_store(struct address *i, struct address **start,&lt;br /&gt;
               struct address **last);&lt;br /&gt;
void inputs(char *, char *, int), display(struct address *);&lt;br /&gt;
int menu_select(void);&lt;br /&gt;
int main(void)&lt;br /&gt;
{&lt;br /&gt;
  start = last = NULL;  /* initialize start and end pointers */&lt;br /&gt;
  for(;;) {&lt;br /&gt;
    switch(menu_select()) {&lt;br /&gt;
      case 1: enter(); /* enter an address */&lt;br /&gt;
        break;&lt;br /&gt;
      case 2: mldelete(&amp;amp;start, &amp;amp;last); /* remove an address */&lt;br /&gt;
        break;&lt;br /&gt;
      case 3: list(); /* display the list */&lt;br /&gt;
        break;&lt;br /&gt;
      case 4: search(); /* find an address */&lt;br /&gt;
        break;&lt;br /&gt;
      case 5: save();  /* save list to disk */&lt;br /&gt;
        break;&lt;br /&gt;
      case 6: load();  /* read from disk */&lt;br /&gt;
        break;&lt;br /&gt;
      case 7: exit(0);&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
/* Select an operation. */&lt;br /&gt;
int menu_select(void)&lt;br /&gt;
{&lt;br /&gt;
  char s[80];&lt;br /&gt;
  int c;&lt;br /&gt;
  printf(&amp;quot;1. Enter a name\n&amp;quot;);&lt;br /&gt;
  printf(&amp;quot;2. Delete a name\n&amp;quot;);&lt;br /&gt;
  printf(&amp;quot;3. List the file\n&amp;quot;);&lt;br /&gt;
  printf(&amp;quot;4. Search\n&amp;quot;);&lt;br /&gt;
  printf(&amp;quot;5. Save the file\n&amp;quot;);&lt;br /&gt;
  printf(&amp;quot;6. Load the file\n&amp;quot;);&lt;br /&gt;
  printf(&amp;quot;7. Quit\n&amp;quot;);&lt;br /&gt;
  do {&lt;br /&gt;
    printf(&amp;quot;\nEnter your choice: &amp;quot;);&lt;br /&gt;
    gets(s);&lt;br /&gt;
    c = atoi(s);&lt;br /&gt;
  } while(c&amp;lt;0 || c&amp;gt;7);&lt;br /&gt;
  return c;&lt;br /&gt;
}&lt;br /&gt;
/* Enter names and addresses. */&lt;br /&gt;
void enter(void)&lt;br /&gt;
{&lt;br /&gt;
  struct address *info;&lt;br /&gt;
  for(;;) {&lt;br /&gt;
    info = (struct address *)malloc(sizeof(struct address));&lt;br /&gt;
    if(!info) {&lt;br /&gt;
      printf(&amp;quot;\nout of memory&amp;quot;);&lt;br /&gt;
      return;&lt;br /&gt;
    }&lt;br /&gt;
    inputs(&amp;quot;Enter name: &amp;quot;, info-&amp;gt;name, 30);&lt;br /&gt;
    if(!info-&amp;gt;name[0]) break;  /* stop entering */&lt;br /&gt;
    inputs(&amp;quot;Enter street: &amp;quot;, info-&amp;gt;street, 40);&lt;br /&gt;
    inputs(&amp;quot;Enter city: &amp;quot;, info-&amp;gt;city, 20);&lt;br /&gt;
    inputs(&amp;quot;Enter state: &amp;quot;, info-&amp;gt;state, 3);&lt;br /&gt;
    inputs(&amp;quot;Enter zip: &amp;quot;, info-&amp;gt;zip, 10);&lt;br /&gt;
    dls_store(info, &amp;amp;start, &amp;amp;last);&lt;br /&gt;
  } /* entry loop */&lt;br /&gt;
}&lt;br /&gt;
/* This function will input a string up to&lt;br /&gt;
   the length in count and will prevent&lt;br /&gt;
   the string from being overrun.  It will also&lt;br /&gt;
   display a prompting message. */&lt;br /&gt;
void inputs(char *prompt, char *s, int count)&lt;br /&gt;
{&lt;br /&gt;
  char p[255];&lt;br /&gt;
  do {&lt;br /&gt;
    printf(prompt);&lt;br /&gt;
    fgets(p, 254, stdin);&lt;br /&gt;
    if(strlen(p) &amp;gt; count) printf(&amp;quot;\nToo Long\n&amp;quot;);&lt;br /&gt;
  } while(strlen(p) &amp;gt; count);&lt;br /&gt;
  p[strlen(p)-1] = 0; /* remove newline character */&lt;br /&gt;
  strcpy(s, p);&lt;br /&gt;
}&lt;br /&gt;
/* Create a doubly linked list in sorted order. */&lt;br /&gt;
void dls_store(&lt;br /&gt;
  struct address *i,   /* new element */&lt;br /&gt;
  struct address **start, /* first element in list */&lt;br /&gt;
  struct address **last /* last element in list */&lt;br /&gt;
)&lt;br /&gt;
{&lt;br /&gt;
  struct address *old, *p;&lt;br /&gt;
  if(*last==NULL) {  /* first element in list */&lt;br /&gt;
    i-&amp;gt;next = NULL;&lt;br /&gt;
    i-&amp;gt;prior = NULL;&lt;br /&gt;
    *last = i;&lt;br /&gt;
    *start = i;&lt;br /&gt;
    return;&lt;br /&gt;
  }&lt;br /&gt;
  p = *start; /* start at top of list */&lt;br /&gt;
  old = NULL;&lt;br /&gt;
  while(p) {&lt;br /&gt;
    if(strcmp(p-&amp;gt;name, i-&amp;gt;name)&amp;lt;0){&lt;br /&gt;
      old = p;&lt;br /&gt;
      p = p-&amp;gt;next;&lt;br /&gt;
    }&lt;br /&gt;
    else {&lt;br /&gt;
      if(p-&amp;gt;prior) {&lt;br /&gt;
        p-&amp;gt;prior-&amp;gt;next = i;&lt;br /&gt;
        i-&amp;gt;next = p;&lt;br /&gt;
        i-&amp;gt;prior = p-&amp;gt;prior;&lt;br /&gt;
        p-&amp;gt;prior = i;&lt;br /&gt;
        return;&lt;br /&gt;
      }&lt;br /&gt;
      i-&amp;gt;next = p; /* new first element */&lt;br /&gt;
      i-&amp;gt;prior = NULL;&lt;br /&gt;
      p-&amp;gt;prior = i;&lt;br /&gt;
      *start = i;&lt;br /&gt;
      return;&lt;br /&gt;
    }&lt;br /&gt;
  }&lt;br /&gt;
  old-&amp;gt;next = i; /* put on end */&lt;br /&gt;
  i-&amp;gt;next = NULL;&lt;br /&gt;
  i-&amp;gt;prior = old;&lt;br /&gt;
  *last = i;&lt;br /&gt;
}&lt;br /&gt;
/* Remove an element from the list. */&lt;br /&gt;
void mldelete(struct address **start, struct address **last)&lt;br /&gt;
{&lt;br /&gt;
  struct address *info;&lt;br /&gt;
  char s[80];&lt;br /&gt;
  inputs(&amp;quot;Enter name: &amp;quot;, s, 30);&lt;br /&gt;
  info = find(s);&lt;br /&gt;
  if(info) {&lt;br /&gt;
    if(*start==info) {&lt;br /&gt;
      *start=info-&amp;gt;next;&lt;br /&gt;
      if(*start) (*start)-&amp;gt;prior = NULL;&lt;br /&gt;
      else *last = NULL;&lt;br /&gt;
    }&lt;br /&gt;
    else {&lt;br /&gt;
      info-&amp;gt;prior-&amp;gt;next = info-&amp;gt;next;&lt;br /&gt;
      if(info!=*last)&lt;br /&gt;
          info-&amp;gt;next-&amp;gt;prior = info-&amp;gt;prior;&lt;br /&gt;
      else&lt;br /&gt;
        *last = info-&amp;gt;prior;&lt;br /&gt;
    }&lt;br /&gt;
    free(info);  /* return memory to system */&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
/* Find an address. */&lt;br /&gt;
struct address *find( char *name)&lt;br /&gt;
{&lt;br /&gt;
  struct address *info;&lt;br /&gt;
  info = start;&lt;br /&gt;
  while(info) {&lt;br /&gt;
    if(!strcmp(name, info-&amp;gt;name)) return info;&lt;br /&gt;
    info = info-&amp;gt;next;  /* get next address */&lt;br /&gt;
  }&lt;br /&gt;
  printf(&amp;quot;Name not found.\n&amp;quot;);&lt;br /&gt;
  return NULL;  /* not found */&lt;br /&gt;
}&lt;br /&gt;
/* Display the entire list. */&lt;br /&gt;
void list(void)&lt;br /&gt;
{&lt;br /&gt;
  struct address *info;&lt;br /&gt;
  info = start;&lt;br /&gt;
  while(info) {&lt;br /&gt;
    display(info);&lt;br /&gt;
    info = info-&amp;gt;next;  /* get next address */&lt;br /&gt;
  }&lt;br /&gt;
  printf(&amp;quot;\n\n&amp;quot;);&lt;br /&gt;
}&lt;br /&gt;
/* This function actually prints the fields in each address. */&lt;br /&gt;
void display(struct address *info)&lt;br /&gt;
{&lt;br /&gt;
    printf(&amp;quot;%s\n&amp;quot;, info-&amp;gt;name);&lt;br /&gt;
    printf(&amp;quot;%s\n&amp;quot;, info-&amp;gt;street);&lt;br /&gt;
    printf(&amp;quot;%s\n&amp;quot;, info-&amp;gt;city);&lt;br /&gt;
    printf(&amp;quot;%s\n&amp;quot;, info-&amp;gt;state);&lt;br /&gt;
    printf(&amp;quot;%s\n&amp;quot;, info-&amp;gt;zip);&lt;br /&gt;
    printf(&amp;quot;\n\n&amp;quot;);&lt;br /&gt;
}&lt;br /&gt;
/* Look for a name in the list. */&lt;br /&gt;
void search(void)&lt;br /&gt;
{&lt;br /&gt;
  char name[40];&lt;br /&gt;
  struct address *info;&lt;br /&gt;
  printf(&amp;quot;Enter name to find: &amp;quot;);&lt;br /&gt;
  gets(name);&lt;br /&gt;
  info = find(name);&lt;br /&gt;
  if(!info) printf(&amp;quot;Not Found\n&amp;quot;);&lt;br /&gt;
  else display(info);&lt;br /&gt;
}&lt;br /&gt;
/* Save the file to disk. */&lt;br /&gt;
void save(void)&lt;br /&gt;
{&lt;br /&gt;
  struct address *info;&lt;br /&gt;
  FILE *fp;&lt;br /&gt;
  fp = fopen(&amp;quot;mlist&amp;quot;, &amp;quot;wb&amp;quot;);&lt;br /&gt;
  if(!fp) {&lt;br /&gt;
    printf(&amp;quot;Cannot open file.\n&amp;quot;);&lt;br /&gt;
    exit(1);&lt;br /&gt;
  }&lt;br /&gt;
  printf(&amp;quot;\nSaving File\n&amp;quot;);&lt;br /&gt;
  info = start;&lt;br /&gt;
  while(info) {&lt;br /&gt;
    fwrite(info, sizeof(struct address), 1, fp);&lt;br /&gt;
    info = info-&amp;gt;next;  /* get next address */&lt;br /&gt;
  }&lt;br /&gt;
  fclose(fp);&lt;br /&gt;
}&lt;br /&gt;
/* Load the address file. */&lt;br /&gt;
void load()&lt;br /&gt;
{&lt;br /&gt;
  struct address *info;&lt;br /&gt;
  FILE *fp;&lt;br /&gt;
  fp = fopen(&amp;quot;mlist&amp;quot;, &amp;quot;rb&amp;quot;);&lt;br /&gt;
  if(!fp) {&lt;br /&gt;
    printf(&amp;quot;Cannot open file.\n&amp;quot;);&lt;br /&gt;
    exit(1);&lt;br /&gt;
  }&lt;br /&gt;
  /* free any previously allocated memory */&lt;br /&gt;
  while(start) {&lt;br /&gt;
    info = start-&amp;gt;next;&lt;br /&gt;
    free(info);&lt;br /&gt;
    start = info;&lt;br /&gt;
  }&lt;br /&gt;
  /* reset top and bottom pointers */&lt;br /&gt;
  start = last = NULL;&lt;br /&gt;
  printf(&amp;quot;\nLoading File\n&amp;quot;);&lt;br /&gt;
  while(!feof(fp)) {&lt;br /&gt;
    info = (struct address *) malloc(sizeof(struct address));&lt;br /&gt;
    if(!info) {&lt;br /&gt;
      printf(&amp;quot;Out of Memory&amp;quot;);&lt;br /&gt;
      return;&lt;br /&gt;
    }&lt;br /&gt;
    if(1 != fread(info, sizeof(struct address), 1, fp)) break;&lt;br /&gt;
    dls_store(info, &amp;amp;start, &amp;amp;last);&lt;br /&gt;
  }&lt;br /&gt;
  fclose(fp);&lt;br /&gt;
}&lt;br /&gt;
           &lt;br /&gt;
       &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>