| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1269 人关注过本帖
标题:[讨论]打死我都不相信有错误(双向链表)
只看楼主 加入收藏
yangzhifu
Rank: 1
等 级:新手上路
威 望:2
帖 子:433
专家分:0
注 册:2007-4-11
收藏
 问题点数:0 回复次数:14 
[讨论]打死我都不相信有错误(双向链表)
如下是我的代码:
错误是结构体的定义
'node' : 'struct' type redefinition
大家说说为什么错(vc6.0)
YOVdDlOq.txt (202 Bytes) [讨论]打死我都不相信有错误(双向链表)





wNePCh6d.txt (149 Bytes) [讨论]打死我都不相信有错误(双向链表)



gaWysz75.txt (1.96 KB) [讨论]打死我都不相信有错误(双向链表)

搜索更多相关主题的帖子: 链表 
2007-10-10 22:09
yangzhifu
Rank: 1
等 级:新手上路
威 望:2
帖 子:433
专家分:0
注 册:2007-4-11
收藏
得分:0 

#define YES 1
#define NO 0
typedef int elemtype;
typedef struct node
{
elemtype data;
struct node *next;
struct node *prior;
}*dlink;

/***********************************************/
#include<stdio.h>
#include<malloc.h>
#include<stdlib.h>
#include"2-3define.h"
dlink creatdlink(int n)
{
int j;
dlink head,p,s;
p=head=(dlink)malloc(sizeof(dlink));
for(j=0;j<n;j++)
{
s=(dlink)malloc(sizeof(dlink));
printf("Input the %d data:\n",j);
scanf("%d",&s->data);
p->next=s;
s->next=NULL;
s->prior=p;
p=s;
}//P->prior通个p=s来实现
p->next=NULL;
return head;
}
int getlen(dlink head)
{
int j=0;
dlink p;
p=head->next;
while(p!=NULL)
{
j++;
p=p->next;
}
return j;
}
int getelem(dlink head ,int n)
{ dlink q;
int j;
q=head->next;
if(head->next==NULL)
printf("The link is empty !\n");
return NO;
while(q!=NULL&&j<n)
{
q=q->next;
j++;
}
if(q==NULL)
return NO;
else
return q->data;
}
int locate(dlink head ,elemtype x)

{
dlink q;
int j=1;
q=head->next;
if(head->next=NULL)
printf("The link is empty !\n");
while(q!=NULL&&q->data!=x)
{
q=q->next;
j++;
}
if(q==NULL)
return NO;
else
return j;
}
int delete(dlink head ,int q)
{
dlink p,s;
int j;
if(q<1)
printf("wrong input:\n");
return NO;
p=head ;
j=0;
while(p->next!=NULL&&j<q)
{
p=p->next;
j++;
}
if(p->next==NULL)
return NO;
s=p->next;
p->next=s->next;
if(s->next!=NULL)
s->next->prior=p;
free(s);
return YES;
}
int insert(dlink head ,int p,elemtype x)
{
dlink q,s;
int j;
if(p<1)
printf("wrong input:\n");
return NO;
q=head;
j=0;
while (q!=NULL&&j<p-1)
{
q=q->next;
j++;
}
if(q==NULL)
return NO;
s=(dlink)malloc(sizeof(dlink));
s->data=x;
s->next=q->next;
s->prior=q;
if(q->next!=NULL)
q->next->prior=s;
q->next=s;
return YES;
}
void list(dlink head)
{
dlink p;
p=head->next;
while(p!=NULL)
{
printf("%4d",p->next->data);
p=p->next;
}
printf("\n");
while(p!=NULL)
{
printf("%4d",p->data);
p=p->prior;
}
printf("\n");

}
/*******************************************************/
#include<stdio.h>
#include"2-3define.h"
#include"2-3lib.h"
void main()
{
int i;
dlink H;

dlink creatdlink(int n);
void list(dlink head);
i=4;
H=creatdlink(i);
list(H);
}
//随意用的两个函数




方寸之内,剖天下; 方坛之内,析自我;
2007-10-10 22:11
雨中飞燕
Rank: 3Rank: 3
等 级:禁止访问
威 望:8
帖 子:2200
专家分:0
注 册:2007-8-9
收藏
得分:0 
重复包含重复声明错误
主cpp里struct node 因为有两次包含,所以重复



by 雨中飞燕 QQ:78803110 C/C++讨论群:46520219
[url=http://yzfy.org/]C/C++算法习题(OnlineJudge):[/url] http://yzfy.org/
Blog: http://yzfy.programfan.com

[url=http://bbs.bc-cn.net/viewthread.php?tid=163571]请大家不要用TC来学习C语言,点击此处查看原因[/url] [url=http://blog.programfan.com/article.asp?id=24801]请不要写出非int声明的main函数[/url]
[url=http://bbs.bc-cn.net/viewthread.php?tid=162918]C++编写的Windows界面游戏[/url]
2007-10-10 22:19
aoaoaoao
Rank: 1
等 级:新手上路
帖 子:81
专家分:0
注 册:2007-5-14
收藏
得分:0 
好象是说 结构体 node被重复定义了..
2007-10-10 22:21
yangzhifu
Rank: 1
等 级:新手上路
威 望:2
帖 子:433
专家分:0
注 册:2007-4-11
收藏
得分:0 
对啊,怎么办

方寸之内,剖天下; 方坛之内,析自我;
2007-10-10 22:45
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
#include"2-3define.h"
#include"2-3lib.h"

看看这里面,应该会有node的定义,所以你重复定义了.

倚天照海花无数,流水高山心自知。
2007-10-10 22:59
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
如果有相同的 node定义就改成别的.
你把这两个头文件有关 node的定义发上来看看,
我估计是这里面的重复定义.

倚天照海花无数,流水高山心自知。
2007-10-10 23:10
yangzhifu
Rank: 1
等 级:新手上路
威 望:2
帖 子:433
专家分:0
注 册:2007-4-11
收藏
得分:0 
在最上面,我不知道怎么改:
下面的方法不行typedef struct node
{
elemtype data;
struct node *next,*prior;

}*dlink;

方寸之内,剖天下; 方坛之内,析自我;
2007-10-11 09:55
永夜的极光
Rank: 6Rank: 6
等 级:贵宾
威 望:27
帖 子:2721
专家分:1
注 册:2007-10-9
收藏
得分:0 
用查找与替换把所有node替换成别的,比如node1看看行不行

从BFS(Breadth First Study)到DFS(Depth First Study)
2007-10-11 10:03
雨中飞燕
Rank: 3Rank: 3
等 级:禁止访问
威 望:8
帖 子:2200
专家分:0
注 册:2007-8-9
收藏
得分:0 

#define YES 1
#define NO 0
typedef int elemtype;
typedef struct node
{
elemtype data;
struct node *next;
struct node *prior;
}*dlink;

改:
#ifndef _MYDEFINEFILE_H
#define _MYDEFINEFILE_H

#define YES 1
#define NO 0
typedef int elemtype;
typedef struct node
{
elemtype data;
struct node *next;
struct node *prior;
}*dlink;

#endif



by 雨中飞燕 QQ:78803110 C/C++讨论群:46520219
[url=http://yzfy.org/]C/C++算法习题(OnlineJudge):[/url] http://yzfy.org/
Blog: http://yzfy.programfan.com

[url=http://bbs.bc-cn.net/viewthread.php?tid=163571]请大家不要用TC来学习C语言,点击此处查看原因[/url] [url=http://blog.programfan.com/article.asp?id=24801]请不要写出非int声明的main函数[/url]
[url=http://bbs.bc-cn.net/viewthread.php?tid=162918]C++编写的Windows界面游戏[/url]

2007-10-11 10:04
快速回复:[讨论]打死我都不相信有错误(双向链表)
数据加载中...
 
   



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

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