#include <stdio.h> #include <stdlib.h> #define N 10 typedef struct student { int num; float score; struct student *next; }stu; stu *creat() { int i; stu *p,*head = NULL,*tail = head; for (i = 0; i < N; i++) { p = (stu *)malloc(sizeof(stu)); scanf("%d%f",&p->num,&p->score); p->next = NULL; if ( p->num <= 0) { free(p); break; } if(head == NULL) head = p; else tail->next = p; tail = p; } return head; } void print(stu *p) { while (p != NULL) { printf("%d\t%.2f\n",p->num,p->score); p = p->next; } } stu *link(stu *p1,stu *p2) { stu *p,*head; if ( p1->num < p2->num ) { head = p = p1; p1 = p1->next; } else { head = p = p2; p2 = p2->next; } while ( (p1 != NULL) && (p2 != NULL )) { if (p1->num < p2->num) { p->next = p1; p = p1; p1 = p1->next; } else { p->next = p2; p = p2; p2 = p2->next; } } if(p1 != NULL) p->next = p1; else p->next = p2; return head; } int main() { stu *a,*b,*c; printf("\n請輸入鏈表a的信息,學號小於等於零時結束輸入:格式(學號 成績)\n"); a = creat(); printf("\n請輸入鏈表b的信息,學號小於等於零時結束輸入:格式(學號 成績)\n"); b = creat(); printf("\n鏈表a的信息爲:\n"); print(a); printf("\n鏈表b的信息爲:\n"); print(b); c = link(a,b); printf("\n合併後的鏈表信息爲:\n"); print(c); return 0; }
已有a,b兩個鏈表,每個鏈表中的結點包括學號,成績。要求把兩個鏈表合併,按學號升序排列。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.