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

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 C# 调用Bartender打印机打印
  • ¥100 华为ensp只要2-9实验运行结果能做的来加我QQ
  • ¥15 我这个代码哪里有问题 acm 平台上显示错误 90%,我自己运行好像没什么问题
  • ¥50 C#编程中使用printDocument类实现文字排版打印问题
  • ¥15 找会编程的帅哥美女 可以用MATLAB里面的simulink编程,用Keil5编也可以。
  • ¥15 已知隐函数其中一个变量τ的具体值,求另一个变量
  • ¥15 r语言Hurst指数
  • ¥15 Acrn IVSHMEM doorbell问题
  • ¥15 yolov5中的val测试集训练时数量变小问题
  • ¥15 MPLS/VPN实验中MPLS的配置问题