
数据结构(C语言)顺序表的合并 求高手修改。。。。
怎么编译都通不过#include<iostream>#include<stdlib.h>usingnamespacestd;typedefintdatatype;#def...
怎么编译都通不过
#include<iostream>
#include<stdlib.h>
using namespace std;
typedef int datatype;
#define maxsize 1024
typedef struct
{
datatype data[maxsize];
int last;
}sequenlist;
void main ()
{
sequenlist *Aptr,*Bptr,*Cptr;
int ch;
int i=0;
while (ch=='\n'||i>19)
{
ch=cin();
*Aptr.data[i]=ch;
i++;
}
ch=0;
i=0;
while (ch=='\n'||i>19)
{
ch=cin();
*Bptr.data[i]=ch;
i++;
}
*Cptr=*combine(sequenlist *Aptr,sequenlist *Bptr);
for(i=0;i>39||*Cptr.data[i]=='\n';i++)
printf("%d",*combine.data[i]);
}
void insertlist (sequenlist *istpter,int x)
{
int i,j=0;
do {
if (x<=lstptr.data[i])
break;
else i++;
}until (i>=last);
if (istptr->last>=maxsize)
{
printf ("overflow");
exit (overflow);
}
for (isptr->last-1;j>=i;j--)
{
istptr->data[j+1]=istptr->data[j];
istptr->data[i]=x;
istptr->last++;
}
}
sequenlist *conbine (sequenlist *scrptr,sequenlist *sinkptr)
{
int x;
int j;
for (j=0;j<scrptr->last;j++)
inserlist (*sinkptr,*sinkptr->data[j]);
} 展开
#include<iostream>
#include<stdlib.h>
using namespace std;
typedef int datatype;
#define maxsize 1024
typedef struct
{
datatype data[maxsize];
int last;
}sequenlist;
void main ()
{
sequenlist *Aptr,*Bptr,*Cptr;
int ch;
int i=0;
while (ch=='\n'||i>19)
{
ch=cin();
*Aptr.data[i]=ch;
i++;
}
ch=0;
i=0;
while (ch=='\n'||i>19)
{
ch=cin();
*Bptr.data[i]=ch;
i++;
}
*Cptr=*combine(sequenlist *Aptr,sequenlist *Bptr);
for(i=0;i>39||*Cptr.data[i]=='\n';i++)
printf("%d",*combine.data[i]);
}
void insertlist (sequenlist *istpter,int x)
{
int i,j=0;
do {
if (x<=lstptr.data[i])
break;
else i++;
}until (i>=last);
if (istptr->last>=maxsize)
{
printf ("overflow");
exit (overflow);
}
for (isptr->last-1;j>=i;j--)
{
istptr->data[j+1]=istptr->data[j];
istptr->data[i]=x;
istptr->last++;
}
}
sequenlist *conbine (sequenlist *scrptr,sequenlist *sinkptr)
{
int x;
int j;
for (j=0;j<scrptr->last;j++)
inserlist (*sinkptr,*sinkptr->data[j]);
} 展开
1个回答
展开全部
/*
**太多错误了,包括语法和逻辑上的错误都有。。。。
**我修改了一下,现在可以了。
**请注意,下面我说的字符串均指纯数字字符串,这个程序中是以字符方式来处理成数字的
**输入的时候,第一次输入的必须是顺序串(否则还要加一个排序算法),
**不是顺序串的话输入也没有问题,但是第一个字符串不会被排序
**第二个字符串不要求顺序。因为是一个个插入第一个字符串的对应位置
**而且这里输入的会被按照单个字符来录入
**(即数组元素只能为0~9中的任一个整数),
**如果想要以多位数(比如一个数组元素为67、345、2351等)来作为一个数组元素,
**则要修改判断输入的部分(我只是根据你的来改的,不知道是不是你想要的结果)。
*/
#include<iostream>
//可去掉#include<stdlib.h>
using namespace std;
typedef int datatype;
#define maxsize 1024
typedef struct
{
datatype data[maxsize];
int last;
}sequenlist;
sequenlist *combine (sequenlist *scrptr,sequenlist *sinkptr);//添加函数声明
void main ()
{
sequenlist *Aptr,*Bptr,*Cptr;
Aptr = new sequenlist;//注意,要申请空间,初始化指针,下同
Bptr = new sequenlist;
Cptr = NULL;
//Cptr不用申请空间,因为后面有返回指针,这里初始为NULL,以防非法操作
char ch; //注意这里
int i=0;
//注意这里
do
{
ch = getchar();
Aptr->data[i]= ch - '0';//*Aptr.data[i]——>Aptr->data[i]
i++;
}
while (ch!='\n' && i<maxsize);
Aptr->last = i-1; //添加这句
i = 0;
do
{
ch = getchar();
Bptr->data[i]= ch - '0';//*Aptr.data[i]——>Aptr->data[i]
i++;
}
while (ch!='\n' && i<maxsize);
Bptr->last = i-1;
Cptr=combine(Aptr,Bptr);//注意这里
for(i=0;i<Cptr->last;i++)//注意
printf("%d",Cptr->data[i]);
delete Aptr;//前面new的,现在要delete,否则内存泄漏(虽然编译可通过)
delete Bptr;
Aptr = Bptr = Cptr = NULL;//这句可要可不要,只是一个习惯,即delete掉的指针要置空,以防非法操作。
}
void insertlist (sequenlist *lstptr,int x)//istpter——>lstptr
{
int i=0,j=0;
//没有do....until ();应用while
while(i<lstptr->last)
{
if (x<=lstptr->data[i])
break;
else i++;
}
if (lstptr->last>=maxsize)
{
printf ("overflow");
exit(0);//exit (overflow);overflow不是一个整数值
}
for (j=lstptr->last-1;j>=i;j--)//注意,j=lstptr->last-1
{
lstptr->data[j+1]=lstptr->data[j];
// lstptr->data[i]=x;
// lstptr->last++;
//这两句要放for外面
}
lstptr->data[i]=x;
lstptr->last++;
}
sequenlist *combine (sequenlist *scrptr,sequenlist *sinkptr)
{
//int x;不需要
int j;
for (j=0;j<sinkptr->last;j++)
insertlist (scrptr,sinkptr->data[j]);
return scrptr;//注意
}
**太多错误了,包括语法和逻辑上的错误都有。。。。
**我修改了一下,现在可以了。
**请注意,下面我说的字符串均指纯数字字符串,这个程序中是以字符方式来处理成数字的
**输入的时候,第一次输入的必须是顺序串(否则还要加一个排序算法),
**不是顺序串的话输入也没有问题,但是第一个字符串不会被排序
**第二个字符串不要求顺序。因为是一个个插入第一个字符串的对应位置
**而且这里输入的会被按照单个字符来录入
**(即数组元素只能为0~9中的任一个整数),
**如果想要以多位数(比如一个数组元素为67、345、2351等)来作为一个数组元素,
**则要修改判断输入的部分(我只是根据你的来改的,不知道是不是你想要的结果)。
*/
#include<iostream>
//可去掉#include<stdlib.h>
using namespace std;
typedef int datatype;
#define maxsize 1024
typedef struct
{
datatype data[maxsize];
int last;
}sequenlist;
sequenlist *combine (sequenlist *scrptr,sequenlist *sinkptr);//添加函数声明
void main ()
{
sequenlist *Aptr,*Bptr,*Cptr;
Aptr = new sequenlist;//注意,要申请空间,初始化指针,下同
Bptr = new sequenlist;
Cptr = NULL;
//Cptr不用申请空间,因为后面有返回指针,这里初始为NULL,以防非法操作
char ch; //注意这里
int i=0;
//注意这里
do
{
ch = getchar();
Aptr->data[i]= ch - '0';//*Aptr.data[i]——>Aptr->data[i]
i++;
}
while (ch!='\n' && i<maxsize);
Aptr->last = i-1; //添加这句
i = 0;
do
{
ch = getchar();
Bptr->data[i]= ch - '0';//*Aptr.data[i]——>Aptr->data[i]
i++;
}
while (ch!='\n' && i<maxsize);
Bptr->last = i-1;
Cptr=combine(Aptr,Bptr);//注意这里
for(i=0;i<Cptr->last;i++)//注意
printf("%d",Cptr->data[i]);
delete Aptr;//前面new的,现在要delete,否则内存泄漏(虽然编译可通过)
delete Bptr;
Aptr = Bptr = Cptr = NULL;//这句可要可不要,只是一个习惯,即delete掉的指针要置空,以防非法操作。
}
void insertlist (sequenlist *lstptr,int x)//istpter——>lstptr
{
int i=0,j=0;
//没有do....until ();应用while
while(i<lstptr->last)
{
if (x<=lstptr->data[i])
break;
else i++;
}
if (lstptr->last>=maxsize)
{
printf ("overflow");
exit(0);//exit (overflow);overflow不是一个整数值
}
for (j=lstptr->last-1;j>=i;j--)//注意,j=lstptr->last-1
{
lstptr->data[j+1]=lstptr->data[j];
// lstptr->data[i]=x;
// lstptr->last++;
//这两句要放for外面
}
lstptr->data[i]=x;
lstptr->last++;
}
sequenlist *combine (sequenlist *scrptr,sequenlist *sinkptr)
{
//int x;不需要
int j;
for (j=0;j<sinkptr->last;j++)
insertlist (scrptr,sinkptr->data[j]);
return scrptr;//注意
}

2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件...
点击进入详情页
本回答由光点科技提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询