m0_62138486 2022-09-13 11:52 采纳率: 98.6%
浏览 10
已结题

画圈的那部分是什么意思?

img


#include<stdio.h>
typedef struct LNode{
int data;
struct LNode *next;
}*list,LNode; //别名 list为结构指针,LNode为结构
list Scanf(int x);
list tong(list A,list B);
void Print(list head);
int main()
{
int na,nb;
list A=(list)malloc(sizeof(LNode)),B=(list)malloc(sizeof(LNode)),head;
head=NULL;//头指针置为空
scanf("%d %d",&na,&nb);
A=Scanf(na);
B=Scanf(nb);
head=tong(A,B);
if(head==NULL)
printf("NULL");
else Print(head);
return 0;
}
list Scanf(int x)//尾插法建立单链表
{
list head=(list)malloc(sizeof(LNode)),t;//建立头节点head
head->next=NULL;//头节点head指针域next为空
list p=head;//尾指针p指向头节点
for(int i=0;i<x;i++)
{
t=(list)malloc(sizeof(LNode));//生成新节点t
scanf("%d",&t->data);//读入的数据给新节点t的数据域
t->next=NULL;//新节点t的指针域为空
p->next=t;//将新节点t链接尾结点的后面
p=t;//后插,修改尾指针p,使它指向新节点t
}
return head;
}
list tong(list A,list B)//求交集
{
list head=(list)malloc(sizeof(LNode));
head=NULL;
list a,b,t,L;
for(a=A->next;a!=NULL;a=a->next)//指针域
{
for(b=B->next;b!=NULL;b=b->next)//指针域
{
if(a->data==b->data)//数据域
{
t=(list)malloc(sizeof(LNode));
t->data=a->data;
if(head==NULL)
head=t;
else
L->next=t;
L=t;
L->next=NULL;
}
}
}
return head;
}
void Print(list head)
{
for(list t=head;t!=NULL;t=t->next)
{
if(t==head)
printf("%d",t->data);
else
printf(" %d",t->data);
}
}

img

img

  • 写回答

2条回答 默认 最新

  • 私房菜 移动开发领域优质创作者 2022-09-13 14:48
    关注

    第一个,是为了确定指针是否为NULL
    第二个,是为了确定 head是否为NULL,也就是刚新建第一个节点,最后将链表头返回即可

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 9月22日
  • 已采纳回答 9月14日
  • 创建了问题 9月13日

悬赏问题

  • ¥15 Matlab在app上输入带有矩阵形式的初始条件发生错误
  • ¥15 CST仿真别人的模型结果仿真结果S参数完全不对
  • ¥15 误删注册表文件致win10无法开启
  • ¥15 请问在阿里云服务器中怎么利用数据库制作网站
  • ¥60 ESP32怎么烧录自启动程序
  • ¥50 html2canvas超出滚动条不显示
  • ¥15 java业务性能问题求解(sql,业务设计相关)
  • ¥15 52810 尾椎c三个a 写蓝牙地址
  • ¥15 elmos524.33 eeprom的读写问题
  • ¥15 用ADS设计一款的射频功率放大器