标题:[求助]数据结构问题
取消只看楼主
hyl8729252
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2006-6-5
 问题点数:0 回复次数:2 
[求助]数据结构问题

这是我写的一个顺序表结构, 这个程序里面是对 数据的插入和删除,我不知道错在那了,不能对数据插入
问一下,数据的插入和删除能在一个程序里面实现嘛! 高手帮我改改.谢谢!!

#include "Stdio.h"
#include "Conio.h"

#define MAXSIZE 100

typedef int datatype;
typedef struct
{
datatype data[MAXSIZE];
int last;
}SeqList;

SeqList *init_SeqList();
void input(SeqList *L);
void output(SeqList *L);
int insert_SeqList(SeqList *L,int i,datatype x);
int delete_SeqList(SeqList *L,int i);

main()
{
SeqList *L;
datatype x;
int i;
L=init_SeqList();
input(L);
printf("insert which number");
scanf("%d",&x);
printf("where (1-100)\n");
scanf("%d",&i);
output(L);
if(insert_SeqList(L,i,x)==1)
output(L);
if(delete_SeqList(L,i))
output(L);
getch();
}

SeqList *init_SeqList()
{
SeqList *L;
L=(SeqList *)malloc(sizeof(SeqList));
L->last=-1;
return L;
}

void input(SeqList *L)
{
int n;
printf("input numbers(less than 100):\n");
for(n=0;n<100;n++)
{
scanf("%d",&L->data[n]);
if(L->data[n]==0) break;
L->last=n;
}
}

void output(SeqList *L)
{
int n;
for(n=0;n<=L->last;n++)
printf("%d\t",L->data[n]);
}

int insert_SeqList(SeqList*L,int i,datatype x)
{
int j;
if(L->last==MAXSIZE-1)
{
printf("full");
return -1;
}
if(i<1||L->last+2)
{
printf("wrong");
return 0;
}
for(j=L->last;j>=i-1;j--)
{
L->data[j+1]=L->data[j];
}
L->data[i-1]=x;
L->last++;
return 1;
}

int delete_SeqList(SeqList *L,int i)
{
int j;
if(i<1||L->last+1)
{
printf("bu cun zai");
return 0;
}
for(j=i;j<=L->last;j++)
{
L->data[j-1]=L->data[j];
}
L->last--;
return 1;
}




搜索更多相关主题的帖子: 数据结构 SeqList int void 
2006-10-11 10:23
hyl8729252
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2006-6-5
得分:0 
怎么没人来帮我看看啊~~~~~~~郁闷!

2006-10-11 10:29
hyl8729252
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2006-6-5
得分:0 
谢谢了,小弟, 刚刚学数据结构,还有很多地方不懂.以后还请大家多多指教啊!

2006-10-11 22:21



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-95452-1-1.html




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

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