原题链接:[编程入门]链表合并
解题思路:定义结构体->创建链表->合并链表->链表排序->打印排序后链表
注意事项:知识点:
1.struct Link *L1 = AddNode(n); //定义指针指向创建好的链表;
2.struct Link *AddNode(int n); //表示返回struct Link *指针;
3.对于int *p而言;p是一个指针,保存着地址;*p则会访问该地址保存的变量;
4.ContactLink(L1,L2)中的L1,L2传递的是他们各自的头指针(保存着地址)。
参考代码:
#include#includestruct Link //定义结构体
{
int id;
int score;
struct Link *next;
};
//函数声明
struct Link *AddNode(int n);
void ContactLink(struct Link *L1,struct Link *L2);
void Sort(struct Link *L1);
void Print(struct Link *L1);
void main() //主函数
{
int n,m;
scanf("%d %d",&n,&m);
struct Link *L1 = AddNode(n); //定义指针指向创建好的链表
struct Link *L2 = AddNode(m);
ContactLink(L1,L2);
Sort(L1);
Print(L1);
}
struct Link *AddNode(int n) //创建链表
{
struct Link *head = NULL;
head = (struct Link *)malloc(sizeof(struct Link));
if(head == NULL)
{
printf("error");
exit(0);
}
struct Link *pr = head;
int i = 0;
for(;i < n; i++)
{
struct Link *p = NULL;
p = (struct Link *)malloc(sizeof(struct Link));
if(p == NULL)
{
printf("error");
exit(0);
}
else
{
scanf("%d %d",&p->id,&p->score);
pr->next = p;
pr = p;
}
}
pr->next = NULL;
return head;
}
void ContactLink(struct Link *L1,struct Link *L2) //合并链表
{
while(L1->next != NULL)
L1 = L1->next;
L1->next = L2->next;
free(L2);
}
void Sort(struct Link *L1) //链表排序
{
struct Link temp,*p,*q;
for(p = L1->next; p->next != NULL;p = p->next)
for(q = p->next;q != NULL; q = q->next)
{
if(p->id > q->id)
{
temp = *p; //交换数据域
*p = *q;
*q = temp;
temp.next = p->next; //交换指针域
p->next = q->next;
q->next = temp.next;
}
}
}
void Print(struct Link *L1) //打印链表
{
struct Link *m = L1->next;
while(m != NULL)
{
printf("%d %d\n",m->id,m->score);
m = m->next;
}
}0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复