数据结构之线性表
线性表之顺序存储:
1 sqlist.h 2 #ifndef _SQLIST_H 3 #define _SQLIST_H 4 5 #define MAX_SIZE 6 6 typedef struct 7 { 8 int data[MAX_SIZE]; 9 int last; 10 }sqlist,*sqlink; 11 12 void creatList(sqlink L);//建空表 13 int getLength(sqlink L);//求表长 14 int isEmptyList(sqlink L);//是否为空 15 int isFullList(sqlink L);//是否满 16 void clearList(sqlink L);//清空 17 int deleteList(sqlink L, int pos);//删除指定位置的元素 18 int getList(sqlink L, int pos);//获得指定位置的值 19 int locateList(sqlink L, int data);//找指定元素的位置 20 int insertList(sqlink L, int data, int pos);//在指定位置插入元素 21 void showList(sqlink L);//打印线性表 22 #endif 23 24 main.c 25 #include "sqlist.h" 26 #include <stdlib.h> 27 #include <stdio.h> 28 #include <string.h> 29 30 int main() 31 { 32 sqlink H = (sqlink)malloc(sizeof(sqlist)); 33 memset(H->data, 0 ,sizeof(H->data)); 34 H->last = -1; 35 if(H == NULL){ 36 printf("malloc failed\n"); 37 } 38 39 creatList(H); 40 showList(H); 41 42 printf("======insert========\n"); 43 insertList(H, 88, 3); 44 showList(H); 45 46 printf("======delete========\n"); 47 deleteList(H, 2); 48 showList(H); 49 50 printf("======get date at pos========\n"); 51 int value = getList(H, 4); 52 printf("value =%d\n", value); 53 54 printf("======get pos of data========\n"); 55 int pos = locateList(H, 88); 56 printf("position =%d\n", pos); 57 58 } 59 60 sqlist.c 61 #include "sqlist.h" 62 #include <stdio.h> 63 64 void creatList(sqlink L) 65 { 66 int index = 1; 67 int tmpdata = 0; 68 do{ 69 printf("please input %d number:",index); 70 scanf("%d",&tmpdata); 71 if(tmpdata != -1){ 72 L->data[index - 1] = tmpdata; 73 L->last = index - 1; 74 printf("L->last = %d MAX_SIZE = %d\n",L->last, MAX_SIZE); 75 index++; 76 } 77 }while((tmpdata != -1) && (L->last < MAX_SIZE)); 78 79 if(L->last >= MAX_SIZE){ 80 printf("list element not enough\n"); 81 L->last = L->last -1; 82 } 83 }//建空表 84 85 int getLength(sqlink L) 86 { 87 return L->last + 1; 88 }//求表长 89 90 int isEmptyList(sqlink L) 91 { 92 if(L->last == -1) 93 return 1; 94 else 95 return 0; 96 }//是否为空 97 98 int isFullList(sqlink L) 99 { 100 if(L->last == MAX_SIZE - 1) 101 return 1; 102 else 103 return 0; 104 105 }//是否满 106 107 void clearList(sqlink L) 108 { 109 L->last = 0; 110 }//清空 111 112 int deleteList(sqlink L, int pos) 113 { 114 if(isEmptyList(L)){ 115 printf("this list is empty\n"); 116 return 0; 117 } 118 119 if((pos < 0) || (pos > MAX_SIZE -1)){ 120 printf("delete position not correct\n"); 121 return 0; 122 } 123 124 for(int i = pos; i < getLength(L) -1; i++){ 125 L->data[i] = L->data[i+1]; 126 } 127 128 L->last = L->last -1; 129 return 1; 130 }//删除指定位置的元素 131 132 int getList(sqlink L, int pos) 133 { 134 if((pos < 0) || (pos > MAX_SIZE -1)){ 135 printf("position not correct\n"); 136 return 0; 137 } 138 139 return L->data[pos]; 140 }//获得指定位置的值 141 142 int locateList(sqlink L, int data) 143 { 144 if(isEmptyList(L)){ 145 printf("this list is empty\n"); 146 return 0; 147 } 148 149 150 for(int i = 0; i < getLength(L);i++){ 151 if(data == L->data[i]) 152 return i; 153 } 154 155 return -1; 156 }//找指定元素的位置 157 158 int insertList(sqlink L, int data, int pos) 159 { 160 if(isFullList(L)){ 161 printf("this list is full\n"); 162 return 0; 163 } 164 165 if((pos < 0) || pos >(MAX_SIZE -1)){ 166 printf("insert position not correct\n"); 167 return 0; 168 } 169 170 for(int j = getLength(L)- 1; j >= pos; j--){ 171 L->data[j+1] = L->data[j];//j等于pos时,也要往后移 172 } 173 174 L->data[pos] = data; 175 L->last = L->last +1; 176 177 return 1; 178 }//在指定位置插入元素 179 180 void showList(sqlink L) 181 { 182 for(int i = 0; i < getLength(L); i++){ 183 printf("output:%d ",L->data[i]); 184 } 185 printf("\n"); 186 }//打印线性表
线性表之链式存储:
1 linklist.h 2 #ifndef _LINKLIST_H 3 #define _LINKLIST_H 4 5 typedef struct node{ 6 int data; 7 struct node *next; 8 }linkNode,*pLink; 9 10 void creatLinkFromHead(pLink H); 11 12 void creatLinkFromTail(pLink H); 13 14 int insertFromHead(pLink H, int value); 15 16 int insertFromTail(pLink H, int value); 17 18 int getLenOfLink(pLink H); 19 20 int insertFromLocate(pLink H, int pos, int value);//在指定位置插入值 21 22 int deleteFromLocate(pLink H, int pos);//删除指定位置的值 23 24 int modifyFromLocate(pLink H, int pos, int value);//修改指定位置的值 25 26 int findValue(pLink H, int pos);//查找位置找值 27 28 int findPos(pLink H, int value);//通过值找位置 29 30 void showLink(pLink H); 31 32 #endif 33 34 35 linklist.c 36 #include "linklist.h" 37 #include <stdio.h> 38 #include <stdlib.h> 39 40 int insertFromHead(pLink H, int value) 41 { 42 pLink tmpHead = (pLink)malloc(sizeof(linkNode)); 43 if(tmpHead == NULL){ 44 printf("insertFromHead malloc node failed\n"); 45 return -1; 46 } 47 tmpHead->data = value; 48 if(H->next == NULL){ 49 tmpHead->next = NULL; 50 H->next = tmpHead; 51 }else{ 52 tmpHead->next = H->next; 53 H->next = tmpHead; 54 } 55 56 return 0; 57 } 58 59 void creatLinkFromHead(pLink H) 60 { 61 int index = 1; 62 int value = 0; 63 if(H == NULL){ 64 printf("head is null\n"); 65 return ; 66 } 67 while(1){ 68 printf("请输入第%d个数:",index); 69 scanf("%d", &value); 70 if(value == -1){ 71 return; 72 }else{ 73 insertFromHead(H, value); 74 } 75 index++; 76 } 77 return ; 78 } 79 80 int insertFromTail(pLink H, int value) 81 { 82 pLink tmpHead = H; 83 84 pLink tmpNode = (pLink)malloc(sizeof(linkNode)); 85 if(tmpNode == NULL){ 86 printf("insertFromTail malloc node failed\n"); 87 return -1; 88 } 89 tmpNode->data = value; 90 tmpNode->next = NULL; 91 92 while(tmpHead->next != NULL){ //找到最后一个节点 93 tmpHead = tmpHead->next; 94 } 95 96 tmpHead->next = tmpNode; 97 return 0; 98 } 99 100 void creatLinkFromTail(pLink H) 101 { 102 int index = 1; 103 int value = 0; 104 if(H == NULL){ 105 printf("head is null\n"); 106 return ; 107 } 108 109 while(1){ 110 printf("请输入第%d个数:", index); 111 scanf("%d", &value); 112 if(-1 == value){ 113 return ; 114 }else{ 115 insertFromTail(H, value); 116 } 117 } 118 return ; 119 } 120 121 int getLenOfLink(pLink H) 122 { 123 int len = 0; 124 pLink tmpHead = H; 125 while(tmpHead ->next != NULL){ 126 len++; 127 tmpHead = tmpHead->next; 128 } 129 130 return len; 131 } 132 133 int insertFromLocate(pLink H, int pos, int value)//在指定位置插入值 134 { 135 int locate = 1; 136 pLink tmpHead = H; 137 if((pos < 1) || (pos > getLenOfLink(H))){ 138 printf("position is not correct\n"); 139 return -1; 140 } 141 142 pLink tmpNode = (pLink)malloc(sizeof(linkNode)); 143 tmpNode->data = value; 144 145 /*if((pos == 1) && (tmpHead->next != NULL)){ //这种方法插入也可以 146 tmpNode->next = tmpHead->next; 147 tmpHead->next = tmpNode; 148 return 0; 149 }else{ 150 while(tmpHead->next != NULL){ 151 locate++; 152 tmpHead = tmpHead->next; 153 if(pos == locate){ 154 tmpNode->next = tmpHead->next; 155 tmpHead->next = tmpNode; 156 return 0; 157 } 158 } 159 }*/ 160 161 while(tmpHead->next != NULL){ 162 if(pos == locate){ 163 tmpNode->next = tmpHead->next; 164 tmpHead->next = tmpNode; 165 return 0; 166 } 167 locate++; 168 tmpHead = tmpHead->next;//tmpHead指针指向的节点要在locate的前一个位置,即要定位到所找位置的前一个指针 169 } 170 171 return -1; 172 } 173 174 int deleteFromLocate(pLink H, int pos)//删除指定位置的值 175 { 176 int locate = 1; 177 pLink tmpHead = H; 178 if((pos < 1) || (pos > getLenOfLink(H))){ 179 printf("position is not correct\n"); 180 return -1; 181 } 182 183 pLink tmpNode = NULL; 184 while(tmpHead->next != NULL){ 185 if(pos == locate){ 186 tmpNode = tmpHead->next ; 187 tmpHead->next = tmpNode->next; 188 return 0; 189 } 190 locate++; 191 tmpHead = tmpHead->next; 192 } 193 return -1; 194 } 195 196 int modifyFromLocate(pLink H, int pos, int value)//修改指定位置的值 197 { 198 int locate = 1; 199 pLink tmpHead = H; 200 if((pos < 1) || (pos > getLenOfLink(H))){ 201 printf("position is not correct\n"); 202 return -1; 203 } 204 205 while(tmpHead->next != NULL){ 206 if(pos == locate){ 207 tmpHead->next->data = value; 208 return 0; 209 } 210 locate++; 211 tmpHead = tmpHead->next; 212 } 213 214 return -1; 215 } 216 217 218 int findValue(pLink H, int pos)//查找位置找值 219 { 220 int locate = 1; 221 pLink tmpHead = H; 222 if((pos < 1) || (pos > getLenOfLink(H))){ 223 printf("position is not correct\n"); 224 return -1; 225 } 226 227 while(tmpHead->next != NULL){ 228 if(pos == locate){ 229 return tmpHead->next->data; 230 } 231 locate++; 232 tmpHead = tmpHead->next; 233 } 234 235 return -1; 236 } 237 238 int findPos(pLink H, int value)//通过值找位置 239 { 240 int pos = 0; 241 if(H == NULL){ 242 printf("link is null\n"); 243 return -1; 244 } 245 246 pLink tmpHead = H; 247 while(tmpHead->next != NULL){ 248 pos++; 249 tmpHead = tmpHead->next; 250 251 if(tmpHead->data == value){ 252 return pos; 253 } 254 } 255 return -1; 256 } 257 258 //链表的翻转 259 int invertlink(pLink H)
{
if(H == NULL){
printf("this link is null\n");
return -1;
}
pLink tmpHead1 = H->next;
pLink tmpHead2 = NULL;
pLink tmpHead3 = H;
tmpHead3->next = NULL;
while(tmpHead1 != NULL){
tmpHead2 = tmpHead1;
tmpHead1 = tmpHead1->next;
if(tmpHead3->next == NULL){
tmpHead2->next = NULL;
tmpHead3->next = tmpHead2;
}else{
tmpHead2->next = tmpHead3->next;
tmpHead3->next = tmpHead2;
}
}
H = tmpHead3;
return 0;
} 288 289 void showLink(pLink H) 290 { 291 if(H == NULL){ 292 printf("show link is null\n"); 293 return ; 294 } 295 296 pLink tmpHead = H; 297 while(tmpHead->next != NULL){ 298 printf("data = %d\n", tmpHead->next->data); 299 tmpHead = tmpHead->next; 300 } 301 return ; 302 } 303 304 linklist_main.c 305 #include "linklist.h" 306 #include <stdio.h> 307 #include <stdlib.h> 308 309 int main() 310 { 311 pLink head = (pLink)malloc(sizeof(linkNode)); 312 head->next = NULL; 313 if(head == NULL){ 314 printf("malloc failed\n"); 315 return -1; 316 } 317 318 /*creatLinkFromHead(head); 319 showLink(head);*/ 320 321 creatLinkFromTail(head); 322 showLink(head); 323 324 printf("+++++++++++++++++++++++++++++++\n"); 325 invertlink(head); 326 showLink(head); 327 328 printf("+++++++++++++++++++++++++++++++\n"); 329 insertFromLocate(head, 5, 88); 330 showLink(head); 331 332 printf("\n+++++++++++++++++++++++++++++++\n"); 333 deleteFromLocate(head, 4); 334 showLink(head); 335 336 printf("\n+++++++++++++++++++++++++++++++\n"); 337 modifyFromLocate(head, 4, 66); 338 showLink(head); 339 340 printf("所找位置的值%d\n",findValue(head, 4)); 341 342 printf("找2所在的位置%d\n",findPos(head, 2)); 343 344 345 346 return 0; 347 }