疯狂代码者 2022-07-20 20:47 采纳率: 60%
浏览 27
已结题

这个链表的代码不知道为什么不行

这个代码不知道为什么不行
#include<stdio.h>

#include<stdlib.h>
struct node
{
int x;
struct node *next;
}
main(){
struct node *h,*p1,*p2;
int i,n,a[10];
printf("请输入链表的长度:");
scanf("%d",&n);
printf("请输入链表的所有元素:");
for(i=0;i<n;i++)
scanf("%d",&a[i]);
for(i=0;i<n;i++)
{
p1=(struct node*)malloc(sizeof(struct node));
p1->x=a[i];
if(h=NULL)
h=p2=p1;
else if(p1->x%2==1)
{
p1->next=h;
h=p1;
}
else
p2->next=p1;
}
printf("构建完成");
p2->next=NULL;
p1=h;
for(i=0;i<n;i++)
{
printf("%d",p1->x);
p1=p1->next;
}
}

运行后,输入完就不行了
  • 写回答

2条回答 默认 最新

  • it_hao528 2022-07-20 22:51
    关注

    1、struct node *h,*p1,*p2;是初始化结构体的指针h p1 p2,此时h p1 p2均不为NULL,但由于未申请分配内存,所以都是野指针
    2、h=NULL是将NULL赋值给h,并不是判断h是否是NULL,所以if(h=NULL)的判断条件就会一直是假的,就算是if(h==NULL)判断的h是否是NULL这条件也会一直是假的,因为h已经初始化并没有赋值为NULL,其就不会是NULL
    3、看你这逻辑应该是要将奇数排在前边,偶数排在后边,但是为偶数的时候只做了p2->next=p1;还缺少将p2往后移一位p2 = p1;
    修改后的代码参考如下:

    #include<stdio.h>
    #include<stdlib.h>
    struct node
    {
        int x;
        struct node *next;
    };
    int main(int argc, const char * argv[]) {
        struct node *h,*p1,*p2;
        int i,n,a[10];
        printf("请输入链表的长度:");
        scanf("%d",&n);
        printf("请输入链表的所有元素:");
        for(i=0;i<n;i++)
        scanf("%d",&a[i]);
        for(i=0;i<n;i++) {
            p1=(struct node*)malloc(sizeof(struct node));
            p1->x=a[i];
            if(i == 0){
                h=p1;
                p2=p1;
            } else if(p1->x%2 == 1){
                p1->next=h;
                h=p1;
            } else {
                p2->next=p1;
                p2 = p1;
            }
        }
        printf("构建完成");
        p2->next=NULL;
        p1=h;
        for(i=0;i<n;i++) {
            printf("%d",p1->x);
            p1=p1->next;
        }
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 8月5日
  • 已采纳回答 7月28日
  • 创建了问题 7月20日

悬赏问题

  • ¥15 高价求中通快递查询接口
  • ¥15 解决一个加好友限制问题 或者有好的方案
  • ¥15 关于#java#的问题,请各位专家解答!
  • ¥15 急matlab编程仿真二阶震荡系统
  • ¥20 TEC-9的数据通路实验
  • ¥15 ue5 .3之前好好的现在只要是激活关卡就会崩溃
  • ¥50 MATLAB实现圆柱体容器内球形颗粒堆积
  • ¥15 python如何将动态的多个子列表,拼接后进行集合的交集
  • ¥20 vitis-ai量化基于pytorch框架下的yolov5模型
  • ¥15 如何实现H5在QQ平台上的二次分享卡片效果?