| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2100 人关注过本帖
标题:[求助]c程序的一个错误
取消只看楼主 加入收藏
andself
Rank: 1
等 级:新手上路
帖 子:60
专家分:0
注 册:2007-9-23
收藏
得分:0 
以下是引用远去的列车在2007-9-29 8:41:12的发言:
L=InsList(L, int i , char e);
L=DelList(L, int i2 , char e2);

改成
L=InsList(L, i , e);
L=DelList(L, i2 , e2);

另外一点:L 与 函数返回值不对应

L 不对应? 那应该怎么改?


2007-09-29 13:35
andself
Rank: 1
等 级:新手上路
帖 子:60
专家分:0
注 册:2007-9-23
收藏
得分:0 

我已经改好了 谢谢大家帮忙 呵呵 这里把改好的发一下 大家运行下
关于链表 的 求长 插入 建立 打印 删除 查找
#include<stdio.h>
#include<malloc.h>
menu()
{
printf(" ____________________________ \n");
printf(" | * MENU * |\n");
printf(" | (1)Creat a new linklist. |\n");
printf(" | (2)Locate. |\n");
printf(" | (3)Get element. |\n");
printf(" | (4)The length of linklist. |\n");
printf(" | (5)Inside an element. |\n");
printf(" | (6)Delete an element. |\n");
printf(" | (7)EXIT. |\n");
printf(" |____________________________|\n");
printf("Please input the number of your choose.\n");
}

int choose()
{
int a;
scanf("%d",&a);
return(a);
}

typedef struct Node
{ char data;
struct Node *next;
}Node,*LinkList;


Node *CreatL()
{
LinkList L;
Node *r,*s;
int flag=1;
char c;
L=(Node *)malloc(sizeof(Node));
L->next=NULL;
r=L;
while(flag)
{
c=getchar();
if(c!='$')
{ s=(Node *)malloc(sizeof(Node));
s->data=c;
r->next=s;
r=s;
}
else
{ flag=0;
r->next=NULL;
}
}
return L;
}

Node *Locate(LinkList L)
{
Node *p;
int b=1;
char i;
scanf("%c",&i);
p=L->next;
while(p!=NULL)
if(p->data!=i)
{
p=p->next;
b++;
}
else break;
printf("This element's locate is %d\n",b);
}

Node *Get(LinkList L)
{
int j,i;
char a;
Node *p;
scanf("%d",&i);
p=L;
j=0;
while(p->next!=NULL&&j<i)
{
p=p->next;
j++;
}
if(i==j)
{
a=p->data;
printf("The i'th element is :%c\n",a);
}
else printf("The i is wrong.\n");
}

int Listlength(LinkList L)
{
Node *p;
int j;
p=L->next;
j=0;
while(p!=NULL)
{
p=p->next;
j++;
}
printf("This Linklist's length is %d\n",j);
}

int InsList(LinkList L,int i,char e)
{
Node *pre,*s;
int k;
pre=L;
k=0;
while(pre!=NULL&&k<i-1)
{
pre=pre->next;
k=k+1;
}
if(k!=i-1)
{
printf("The i is wrong!\n");
return 0;
}
s=(Node *)malloc(sizeof(Node));
s->data=e;
s->next=pre->next;
pre->next=s;
return 1;
}

int DelList(LinkList L,int i2)
{
Node *p,*r;
int k;
p=L;
k=0;
while(p->next!=NULL&&k<i2-1)
{
p=p->next;
k=k+1;
}
if(k!=i2-1)
{
printf("The position is wrong!\n");
return 0;
}
r=p->next;
p->next=p->next->next;
free(r);
return 1;
}


void Print_Node(LinkList L)
{
Node *p;
p=L->next;
while(p)
{
printf("%c--->",p->data);
p=p->next;
}
if(p==NULL)
{
printf("^\n\n\n");
}
}

void Free_Node(LinkList L)
{
Node *p;
p=L->next;
while(p)
{
L->next=p->next;
free(p);
p=L->next;
}
free(L);
}


main()
{
char c,e;
LinkList L;
int i,i2,x=1,y,*p,*h;
printf("Please creat a linklist.\n");
printf("Please input something and enter '$'to end.\n");
L=CreatL();
printf("LinkList has founded!\n");
h=L;
while(x)
{
menu();
y=choose();
if(y>0&&y<8)
{
if(y==1) { printf("please input something and enter '$' to end.\n");
L=CreatL();
printf("LinkList has founded!\n");
}
else
if(y==2) { printf("Please enter the element which you find.\n");
Locate(L);
}

else
if(y==3)
{ printf("Please enter the position of the element which you find.\n");
Get(L);
}
else
if(y==4) Listlength(L);
else
if(y==5)
{
printf("Please input the element e and the locate i.\n");
printf("i :");
scanf("%d",&i);
getchar();
printf("\n");
printf("e :");
scanf("%c",&e);
printf("\n");
L=InsList(L, i , e);
printf("The new LinkList is:\n");
L=h;
Print_Node(L);
}
else
if(y==6)
{
printf("Please input the locate i.\n");
printf("i="); scanf("%d",&i2);
printf("\n");
L=DelList(L, i2);
printf("The new LinkList is:\n");
L=h;
Print_Node(L);
}
else if(y==7) return(1);
printf("(1)Go on (0)EXIT\n");
scanf("%d",&x);
}
else printf("ERROR");
}
Free_Node(L);

}


2007-09-29 20:57
andself
Rank: 1
等 级:新手上路
帖 子:60
专家分:0
注 册:2007-9-23
收藏
得分:0 
需要 类型么?  只是 运行很正常啊  链表么?

2007-09-29 21:47
andself
Rank: 1
等 级:新手上路
帖 子:60
专家分:0
注 册:2007-9-23
收藏
得分:0 

int Listlength(LinkList L)
{
Node *p;
int j;
p=L->next;
j=0;
while(p!=NULL)
{
p=p->next;
j++;
}
printf("This Linklist's length is %d\n",j);
//你的返回值呢?
}

这个 不用返回值 啊 只是输出而已 是不是至少加个 return 1?


2007-09-29 21:51
andself
Rank: 1
等 级:新手上路
帖 子:60
专家分:0
注 册:2007-9-23
收藏
得分:0 
  知道了  谢谢  那 有什么 危害么?

2007-09-29 21:55
andself
Rank: 1
等 级:新手上路
帖 子:60
专家分:0
注 册:2007-9-23
收藏
得分:0 
哪里哪里?  指给我看

2007-09-29 22:00
andself
Rank: 1
等 级:新手上路
帖 子:60
专家分:0
注 册:2007-9-23
收藏
得分:0 
  是不 要  return L;  ?是不是这样?   我试试   谢谢你哈

2007-09-29 22:04
andself
Rank: 1
等 级:新手上路
帖 子:60
专家分:0
注 册:2007-9-23
收藏
得分:0 
哦 试过了 改成 return L; 可以运行
是不是 类型不对 都可能有 潜在 危险啊
谢谢啊

2007-09-29 22:06
andself
Rank: 1
等 级:新手上路
帖 子:60
专家分:0
注 册:2007-9-23
收藏
得分:0 
无奈了 这个程序好不容易弄好 他却说 要整型的 啊 杀了他 他去死吧
气死我了啊 虽然不难 但他 那口气 啊 去死吧啊~~~~~
5555 啊~~~~~~
但还是得改啊~~~ 5555

2007-09-30 18:13
andself
Rank: 1
等 级:新手上路
帖 子:60
专家分:0
注 册:2007-9-23
收藏
得分:0 
不是 啊 我的程序都已经好了
只不过 我设定输入的内容为字符型
给我出题的人 却让我 改成 整型的 去死吧

2007-10-02 09:00
快速回复:[求助]c程序的一个错误
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017783 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved