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

方寸之内,剖天下; 方坛之内,析自我;
2007-10-10 22:45
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
yangzhifu
Rank: 1
等 级:新手上路
威 望:2
帖 子:433
专家分:0
注 册:2007-4-11
收藏
得分:0 
#ifndef _MYDEFINEFILE_H
#define _MYDEFINEFILE_H
的用法是?
_MYDEFINEFILE_H
可以在那里找到?

方寸之内,剖天下; 方坛之内,析自我;
2007-10-11 18:50
yangzhifu
Rank: 1
等 级:新手上路
威 望:2
帖 子:433
专家分:0
注 册:2007-4-11
收藏
得分:0 
我知道#ifndef _MYDEFINEFILE_H
#define _MYDEFINEFILE_H
的用法:编译条件
但是_MYDEFINEFILE_H
不懂

方寸之内,剖天下; 方坛之内,析自我;
2007-10-11 18:51
yangzhifu
Rank: 1
等 级:新手上路
威 望:2
帖 子:433
专家分:0
注 册:2007-4-11
收藏
得分:0 
谢谢了!

方寸之内,剖天下; 方坛之内,析自我;
2007-10-11 19:11
快速回复:[讨论]打死我都不相信有错误(双向链表)
数据加载中...
 
   



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

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