| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 628 人关注过本帖
标题:[求助]顺序表的错误。。。请达人指教
只看楼主 加入收藏
不死鬼鬼
Rank: 1
等 级:新手上路
帖 子:26
专家分:0
注 册:2005-12-9
收藏
 问题点数:0 回复次数:5 
[求助]顺序表的错误。。。请达人指教

/*本程序包括顺序表的建立,输入,输出,插入,删除*/

#include <stdio.h>
#define maxsize 1024


//定义sequenlist类型
typedef int datatype;
typedef struct
{
datatype data[maxsize];
int last;
}sequenlist;


//插入函数 将新节点x插入到顺序表L的第i个位置上
int INSERT(sequenlist *L,datatype x,int i)
{
int j;
if((*L).last >= maxsize - 1) //表空间溢出
{
printf("overflow");
return NULL;
}
else if((i < 1) || (i > (*L).last+1)) //非法位置
{
printf("error");
return NULL;
}
else
{
for(j = (*L).last;j >= i - 1;j--)
(*L).data[j+1] = (*L).data[j]; //将表的位置后移一位,直到下标i-1移到下标i的位置,空出下标i-1的位置(位置i)
(*L).data[i-1] = x; //x赋值到下标i-1(位置i)
(*L).last++; //终端结点下标加1
}
return(1);
}


//删除函数 将顺序表中的第i个结点删除
int DELETE(sequenlist *L,int i)
{
int j;
if((i < 1) || (i > (*L).last+1)) //非法位置
{
printf("error");
return NULL;//凡是返回 NULL的地方就出现警告 "return makes integer from pointer without a cast" 什么意思?
}
else
{
for(j = i;j <= (*L).last;j++) //第i个结点的下标是i-1
(*L).data[j-1] = (*L).data[j]; //用位置i+1(下标i)上的data覆盖位置i上的data(下标i-1)
(*L).last--; //表长减1
}
return (1);
}


//输入函数 当数据不是$时退出
void INPUT(sequenlist *L)
{
int i = 0;
(*L).last = 0;
do
{
printf("Please input the datas:\n");
scanf("%d",L.data[i]); //这里为什么出现错误 "request for member 'data' in something not a stuucture or union"
i++;
(*L).last++;
}while(((*L).data[i]) != "$" && i <= maxsize );//这里警告"comparison between pointer and integer" 什么意思??
}


//输出函数
void OUTPUT(sequenlist *L)
{
int i;
for(i = 0;i <= (*L).last;i++)
printf("%d",(*L).data[i]);
}


//主函数
main()
{
datatype d;
int position;
sequenlist *num;
INPUT(num);
printf("Please input the data that you want and where you want to put it :\n");
scanf("%d %d",&d,&position);
INSERT(num,d,position);
printf("Please input which point do you want to delete:\n");
scanf("%d",&position);
DELETE(num,position);
OUTPUT(num);
}

搜索更多相关主题的帖子: 顺序 指教 
2006-03-30 13:13
不死鬼鬼
Rank: 1
等 级:新手上路
帖 子:26
专家分:0
注 册:2005-12-9
收藏
得分:0 
别告诉我这个问题没人明白。。。。。
2006-03-30 13:45
luo113927
Rank: 1
等 级:新手上路
帖 子:173
专家分:0
注 册:2006-3-15
收藏
得分:0 
scanf("%d",L.data[i]); -------------->scanf("%d",L->data);

以后说话好听点

[此贴子已经被作者于2006-3-30 13:56:11编辑过]

2006-03-30 13:55
不死鬼鬼
Rank: 1
等 级:新手上路
帖 子:26
专家分:0
注 册:2005-12-9
收藏
得分:0 

呵呵..谢谢啊...可是为什么啊....

2006-03-30 14:03
luo113927
Rank: 1
等 级:新手上路
帖 子:173
专家分:0
注 册:2006-3-15
收藏
得分:0 

结构体指针指向元素时的符号

建议去看看书

2006-03-30 14:05
SunShining
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:31
帖 子:2215
专家分:0
注 册:2006-2-17
收藏
得分:0 
你把  '.' 全部改成  '-&gt;'  试下..那样.最起码编译器可以通过!

[glow=255,violet,2]闭关修炼ing...[/glow] [FLASH=360,180]http://www./chinaren.swf[/FLASH]
2006-03-30 17:05
快速回复:[求助]顺序表的错误。。。请达人指教
数据加载中...
 
   



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

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