zoukankan      html  css  js  c++  java
  • 链表程序

      1 #include <stdio.h>
      2 #include <stdlib.h>
      3 
      4 typedef int datatype;
      5 typedef struct node/*链表的每一个节点都是结构体*/
      6 {
      7     datatype data;
      8     struct node *next; 
      9 }linklist;/*linklist 是struct node 的别名,以后就可以用linklist来替代struct node*/
     10 
     11 /*函数声明区*/
     12 /*增删改查这几个函数形参一般都要有头节点*/
     13 linklist * list_create();
     14 int head_insert(linklist *H,datatype value);
     15 int head_delete(linklist *H);
     16 void list_show(linklist *H);
     17 //空----1   非空-----0
     18 int list_empty(linklist *H);
     19 int list_insert(linklist *H,datatype value,int pos);
     20 int list_delete(linklist *H,datatype value);
     21 int list_replace(linklist *H,datatype old,datatype new);
     22 int list_search(linklist *H,datatype value);
     23 void list_recorver(linklist *H);
     24 
     25 int main(int argc, const char *argv[])
     26 {
     27     linklist *H = NULL;
     28     if((H = list_create()) == NULL)
     29     {
     30         printf("list_create failed
    ");
     31         return -1;
     32     }
     33 
     34     head_insert(H,1);
     35     head_insert(H,2);
     36     head_insert(H,3);
     37     head_insert(H,4);
     38     head_insert(H,5);
     39     list_show(H);
     40 
     41     head_delete(H);
     42     list_show(H);
     43 
     44     list_insert(H,10,2);
     45     list_show(H);
     46 
     47     list_delete(H,3);
     48     list_show(H);
     49 
     50     list_replace(H,10,100);
     51     list_show(H);
     52 
     53     printf("search:%d
    ",list_search(H,1));
     54 
     55     list_recorver(H);
     56     list_show(H);
     57 
     58     return 0;
     59 }
     60 /*h是头结点,p是第首节点,因为头结点和首节点到尾节点之间的节点数据类型都一样,都是struct node类型的*/
     61 linklist * list_create()
     62 {
     63     linklist *H = NULL;//定义任何一个指针都需要初始化,一般初始化为NULL,然后再重新指向,否则成为野指针。
     64     if((H = malloc(sizeof(linklist))) == NULL)
     65     {
     66         printf("malloc failed
    ");
     67         return NULL;
     68     }
     69 
     70     H->next = NULL;//防止野指针。
     71 
     72     return H;
     73 }
     74 
     75 int head_insert(linklist *H,datatype value)
     76 {
     77     linklist *p = NULL;/*防止野指针*/
     78     if((p = malloc(sizeof(linklist))) == NULL)
     79     {
     80         printf("malloc node failed
    ");
     81         return -1;
     82     }
     83     /*把p插在h的后面*/
     84     p->data = value;//p的数据域为value
     85     p->next = H->next;//h节点后面的节点的地址为h->next,把h后面的节点的地址 保存在p的指针域(p->next)中。
     86     H->next = p;//把p的内容 给第一个节点的指针域(h->next)
     87 
     88     return 0;
     89 }
     90 
     91 void list_show(linklist *H)
     92 {
     93     while(H->next != NULL)//防止第一个节点后没有节点。
     94     {
     95         printf("%d ",H->next->data);//第二个节点的数据域
     96         H = H->next;//指向下一个节点,H移动。
     97     }
     98     printf("
    ");
     99 }
    100 
    101 int head_delete(linklist *H)
    102 {
    103     linklist *p = H->next;
    104     if(list_empty(H))
    105     {
    106         printf("list is empty
    ");
    107         return -1;
    108     }
    109     
    110     H->next = p->next;
    111     free(p);//p节点所指向的内存被回收,p本身还存在。
    112     p = NULL;
    113 
    114     return 0;
    115 }
    116 
    117 int list_empty(linklist *H)//判断是否为空链表 什么是空链表?只有头节点,没有首节点。
    118 {
    119     if(H->next != NULL)
    120         return 0;
    121     else
    122         return 1;
    123 }
    124 
    125 int list_insert(linklist *H,datatype value,int pos)/*指定位置插入节点,value是值,pos是位置,在pos后面插入*/
    126 {
    127     int i = 0;
    128     linklist *p = H,
    linklist *q = NULL; 129 while(i < pos && p != NULL) 130 { 131 p = p->next; 132 i++;//当i>pos时,p便不再移动,i也不再加一 133 } 134 135 if(p == NULL) 136 { 137 printf("pos error "); 138 return -1; 139 } 140 141 if((q = malloc(sizeof(linklist))) == NULL) 142 { 143 printf("malloc node failed "); 144 return -1; 145 } 146 /*和头插法的插入一样*/ 147 q->data = value; 148 q->next = p->next; 149 p->next = q; 150 151 return 0; 152 } 153 154 int list_delete(linklist *H,datatype value)/*指定位置删除节点*/ 155 { 156 linklist *p = NULL; 157 158 while(H->next != NULL) 159 { 160 if(H->next->data == value) 161 { 162 p = H->next; 163 H->next = p->next; 164 free(p); 165 p = NULL; 166 167 return 0; 168 } 169 else 170 H = H->next; 171 } 172 173 printf("no value"); 174 return -1; 175 } 176 177 int list_replace(linklist *H,datatype old,datatype new)/*改动值*/ 178 { 179 while(H->next != NULL) 180 { 181 if(H->next->data == old) 182 { 183 H->next->data = new; 184 return 0; 185 } 186 else 187 { 188 H = H->next; 189 } 190 } 191 192 return -1; 193 } 194 195 int list_search(linklist *H,datatype value) 196 { 197 int pos = 0; 198 while(H->next != NULL) 199 { 200 if(H->next->data == value) 201 return pos; 202 else 203 { 204 H = H->next; 205 pos++; 206 } 207 } 208 209 printf("no found "); 210 return -1; 211 } 212 213 void list_recorver(linklist *H) 214 { 215 linklist *q = NULL,*p = H->next; 216 H->next = NULL; 217 218 while(p != NULL) 219 { 220 q = p; 221 p = p->next; 222 q->next = H->next; 223 H->next = q; 224 } 225 }
  • 相关阅读:
    HDU 5363 Key Set(快速幂取模)
    HDU 5339 Untitled(暴搜)
    POJ 2406 Power Strings
    Dedecms备份还原网站有效方法
    DEDECMS文章列表每隔8行文章添加分隔虚线
    DEDECMS突破TAG和关键字长度的限制
    为织梦dedecms制作全文RSS订阅源
    DedeCms中Channel用typeid无效
    织梦CMS/Dedecms添加自定义函数
    sql批量换dedecms文章来源和作者
  • 原文地址:https://www.cnblogs.com/renchong/p/5586281.html
Copyright © 2011-2022 走看看