香猪蹄子 2021-04-14 17:46 采纳率: 100%
浏览 68
已采纳

0错误0警告却运行不出结果,请大佬帮忙看看

用dev写的,题目要求是要创建一个有序递增的链表,然后插入一个数据后仍然有序。

点了编译和运行,就只出现0错误0警告那个框,但就是不运行。代码如下:

#include"stdio.h"
#include"stdlib.h" 
typedef struct node{
	int data;
	struct node *next;
}node;

void Linklist(node *L){
	L=(node *)malloc(sizeof(node));
	L->next=NULL;
}

node *insert(node *L){
	node *s,*r;
	int i;
	L->next=NULL;
	r=L;
	for(i=0;i<10;i=i+2){
		s=(node *)malloc(sizeof(node));
		s->data=i+1;
		r->next=s;
		r=s;
	}
	r->next=NULL;
	return L;
}

node *output(node *L){
	node *p=L->next;
	while(p!=NULL){
		printf("%d",p->data);
		p=p->next;
	}
	return L;
}

void add(node *L,int e){
	node *p=L,*s;
    s=(node *)malloc(sizeof(node));
    while(p!=NULL){
    	if(p->data<=e){
    		s->data=e;
    		s->next=p->next;
    		p->next=s;
		}
		else p=p->next;
	}
}
int main(){
	node L;
	int e;
	Linklist(&L);
    insert(&L);
	printf("初始化链表为:\n"); 
	output(&L);
	printf("请输入要插入的数据:\n");
	scanf("%d",&e);
	add(&L,e);
	output(&L);
}
  • 写回答

2条回答 默认 最新

  • CSDN专家-cpp_learner 2021-04-14 20:38
    关注

    点个采纳吧!

    你写那个会有问题,我也不知道怎么该,然后就给你写了一个新的,代码如下:

    void add(node *L, int e) {
    	node *p = L->next, *s;
    	node *q = L;
    	s = (node *)malloc(sizeof(node));
    	s->data = e;
    	while (p != NULL) {
    		/*if (p->data <= e) {
    			s->data = e;
    			s->next = p->next;
    			p->next = s;
    		} else p = p->next;*/
    
    		if (p->data <= e) {
    			q = p;
    			p = p->next;
    		} else {
    			break;
    		}
    	}
    
    	s->next = q->next;
    	q->next = s;
    }

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

报告相同问题?

悬赏问题

  • ¥15 ogg dd trandata 报错
  • ¥15 高缺失率数据如何选择填充方式
  • ¥50 potsgresql15备份问题
  • ¥15 Mac系统vs code使用phpstudy如何配置debug来调试php
  • ¥15 目前主流的音乐软件,像网易云音乐,QQ音乐他们的前端和后台部分是用的什么技术实现的?求解!
  • ¥60 pb数据库修改与连接
  • ¥15 spss统计中二分类变量和有序变量的相关性分析可以用kendall相关分析吗?
  • ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
  • ¥20 神经网络Sequential name=sequential, built=False
  • ¥16 Qphython 用xlrd读取excel报错