标题:那位大侠帮忙看一下错误!!
只看楼主
罗马龙骑士
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2012-9-14
结帖率:100%
 问题点数:0 回复次数:5 
那位大侠帮忙看一下错误!!
#define maxsize 100
#include<stdio.h>
#include<iostream.h>
typedef int elemtype;
typedef struct
{
elemtype data[maxsize];
int length;
}sqlist;

void initlist(sqlist &l)
{
l.length =0;
}
int data[maxsize];
void creatsqlist(sqlist &l,int n)
{
int i;
for(i=0;i<n;i++)

cin>>data[i];
l.length =n;
fflush(stdin);
}

void output(sqlist l)
{
int i;
for(i=0;i<l.length ;i++)
cout<<data[i]<<endl;
}

int isempty(sqlist l)
{
if(l.length ==0)return 1;
else return 0;
}

int getelem(sqlist l,int i)
{
if(i<0||i>=l.length ) return -1;
else return l.data [i];
}

int locateelem(sqlist l,elemtype x)
{
int k=0;
while(k<l.length && l.data [k]!=x)
k++;
if(k<l.length)return k;
else return -1;
}

int insert(sqlist &l,elemtype x,int i)
{
int k;
if(i<0||i>l.length ||l.length==maxsize)
return 0;   
else
{for(k=l.length ;k>=i;k--)
l.data [k]=l.data [k-1];
l.data [i]=x;
l.length =l.length +1;
}
return 1;
}

int DELETE(sqlist &l,int i)
{int k;
if(i<0||i>=l.length )
return 0;
else
{for(k=i;k<l.length ;k++)
l.data [k]=l.data [k+1];
l.length --;
}
return 1;
}

//ok
void clear(sqlist &l)
{
    initlist(l);
}

void margelist(sqlist la,sqlist lb,sqlist &lc)
{
    int i,j,k;
    i=j=k=0;
    while(i<la.length &&j<lb.length )
        if(la.data [i]<lb.data [j])
            lc.data [k++]=la.data [i++];
        else if(la.data [i]>lb.data [j])
            lc.data [k++]=lb.data [j++];
        else
        {lc.data [k++]=lb.data [j++];
        i++;
        }
        while (i<la.length )
            lc.data [k++]=la.data [i++];
        while(j<lb.length )
            lc.data [k++]=la.data [j++];
        lc.length =k;
}

//ok
void output()
{
    int i;
    for(i=0;i<10;i++)
        cout<<" ";
    for(i=0;i<32;i++)
        cout<<"*"<<endl;
}

void mainpp()
{
    int i;
//output();
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"1.建立一个顺序表"<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"2.输出一个顺序表  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"3.在顺序表中查找  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"4.向顺序表中插入一个元素  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"5.删除顺序表中的一个元素  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"6.从顺序表中取出一个元素  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"7.将两个顺序表合并  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"0.退                  出 "<<"*"<<endl;
    for(i=0;i<8;i++) cout<<" ";cout<<"*"<<endl;
//output();
}

//ok

void main()
{
    int n,i,k=1,m,x;
    sqlist l,la,lc;
    initlist (l);
    mainpp();
    while(k)
    {cout<<"请选择0--7:  "<<endl;
    cin>>m;
    getchar();
   
    switch(m)
    {
    case 0: return;
        case 1:{
        cout<<"输入元素值,构成顺序表:"<<endl;
        cout<<"请输入顺序表元素的个数:";
        cin>>n;
        creatsqlist(l,n);
        output(l);
        break;
           }
    case 2: output(l);cout<<endl;break;
    case 3:{
        cout<<"请输入要查找的元素值  :";
        cin>>x;
        k=locateelem(l,x);
        cout<<"要查找的元素的定位:"<<endl;
        break;
           }
    case 4:{
        cout<<"输入要插入元素的位置及其值:";
        fflush(stdin);
        cin>>i;
        cin>>x;
        insert(l,x,i);
        output(l);
        cout<<endl;
        break;
           }
    case 5:
        {
            cout<<"输入要删除元素的位置:";
            fflush(stdin);
            cin>>i;
            output(l);
            break;
        }
    case 6:
        {
            cout<<"请输入要取出的元素的序号:";
            fflush(stdin);
            cin>>i;
            k=getelem(l,i);
            cout<<" 取出的第"<<i<<"个元素的序号:";
            break;
        }
    case 7:{
        initlist(la);
        cout<<" 请输入第2个顺序表元素的个数:";
        cin>>m;
        creatsqlist(la,m);
        output(la);
        margelist(l,la,lc);
        cout<<"输出合并后的顺序表中的元素 :"<<endl;
        output(lc);
        break;
    default :return;
           }
        cout<<" 继续运行吗Y(1)/N(0) :";
            cin>>k;
        if(!k) return ;
    }

    }

搜索更多相关主题的帖子: return void include 
2012-10-09 20:13
寒风中的细雨
Rank: 17Rank: 17Rank: 17Rank: 17Rank: 17
等 级:贵宾
威 望:66
帖 子:1710
专家分:8645
注 册:2009-9-15
得分:0 
大概描述下错误
2012-10-09 20:20
风之子MIKEY
Rank: 3Rank: 3
来 自:江西省抚州市
等 级:论坛游侠
帖 子:39
专家分:108
注 册:2012-9-25
得分:0 
#define maxsize 100
#include<stdio.h>
#include<iostream.h>
typedef int elemtype;
typedef struct
{
elemtype data[maxsize];
int length;
}sqlist;

void initlist(sqlist &l)
{
l.length =0;
}
int data[maxsize];
void creatsqlist(sqlist &l,int n)
{
int i;//要判断n是否大于maxsize
for(i=0;i<n;i++)
cin>>data[i];
l.length =n;
fflush(stdin);
}

void output(sqlist l)//&l
{
int i;
for(i=0;i<l.length ;i++)
cout<<data[i]<<endl;
}

int isempty(sqlist l)//&l

{
if(l.length ==0)return 1;
else return 0;
}

int getelem(sqlist l,int i)//&l
{
if(i<0||i>=l.length ) return -1;
else return l.data [i];
}

int locateelem(sqlist l,elemtype x))//&l
{
int k=0;
while(k<l.length && l.data [k]!=x)
k++;
if(k<l.length)return k;
else return -1;
}

int insert(sqlist &l,elemtype x,int i)
{
int k;
if(i<0||i>l.length ||l.length==maxsize)
return 0;   
else
{for(k=l.length ;k>=i;k--)
l.data [k]=l.data [k-1];
l.data [i]=x;
l.length =l.length +1;
}
return 1;
}

int DELETE(sqlist &l,int i)
{int k;
if(i<0||i>=l.length )
return 0;
else
{for(k=i;k<l.length ;k++)
l.data [k]=l.data [k+1];
l.length --;
}
return 1;
}

//ok
void clear(sqlist &l)
{
    initlist(l);
}

void margelist(sqlist la,sqlist lb,sqlist &lc))//&la,&lb
{
    int i,j,k;
    i=j=k=0;
    while(i<la.length &&j<lb.length )
        if(la.data [i]<lb.data [j])
            lc.data [k++]=la.data [i++];
        else if(la.data [i]>lb.data [j])
            lc.data [k++]=lb.data [j++];
        else
        {lc.data [k++]=lb.data [j++];
        i++;
        }
        while (i<la.length )
            lc.data [k++]=la.data [i++];
        while(j<lb.length )
            lc.data [k++]=la.data [j++];
        lc.length =k;
}

//ok
void output()
{
    int i;
    for(i=0;i<10;i++)
        cout<<" ";
    for(i=0;i<32;i++)
        cout<<"*"<<endl;
}

void mainpp()
{
    int i;
//output();
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"1.建立一个顺序表"<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"2.输出一个顺序表  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"3.在顺序表中查找  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"4.向顺序表中插入一个元素  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"5.删除顺序表中的一个元素  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"6.从顺序表中取出一个元素  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"7.将两个顺序表合并  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"0.退                  出 "<<"*"<<endl;
    for(i=0;i<8;i++) cout<<" ";cout<<"*"<<endl;
//output();
}

//ok

void main()
{
    int n,i,k=1,m,x;
    sqlist l,la,lc;
    initlist (l);
    mainpp();
    while(k)
    {cout<<"请选择0--7:  "<<endl;
    cin>>m;
    getchar();
   
    switch(m)
    {
    case 0: return;
        case 1:{
        cout<<"输入元素值,构成顺序表:"<<endl;
        cout<<"请输入顺序表元素的个数:";
        cin>>n;
        creatsqlist(l,n);
        output(l);
        break;
           }
    case 2: output(l);cout<<endl;break;
    case 3:{
        cout<<"请输入要查找的元素值  :";
        cin>>x;
        k=locateelem(l,x);
        cout<<"要查找的元素的定位:"<<endl;
        break;
           }
    case 4:{
        cout<<"输入要插入元素的位置及其值:";
        fflush(stdin);
        cin>>i;
        cin>>x;
        insert(l,x,i);
        output(l);
        cout<<endl;
        break;
           }
    case 5:
        {
            cout<<"输入要删除元素的位置:";
            fflush(stdin);
            cin>>i;
            output(l);
            break;
        }
    case 6:
        {
            cout<<"请输入要取出的元素的序号:";
            fflush(stdin);
            cin>>i;
            k=getelem(l,i);
            cout<<" 取出的第"<<i<<"个元素的序号:";
            break;
        }
    case 7:{
        initlist(la);
        cout<<" 请输入第2个顺序表元素的个数:";
        cin>>m;
        creatsqlist(la,m);
        output(la);
        margelist(l,la,lc);
        cout<<"输出合并后的顺序表中的元素 :"<<endl;
        output(lc);
        break;
    default :return;
           }
        cout<<" 继续运行吗Y(1)/N(0) :";
            cin>>k;
        if(!k) return ;
    }

    }

2012-10-09 20:35
罗马龙骑士
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2012-9-14
得分:0 
编译出错:fatal error C1004: unexpected end of file found
2012-10-10 13:32
风之子MIKEY
Rank: 3Rank: 3
来 自:江西省抚州市
等 级:论坛游侠
帖 子:39
专家分:108
注 册:2012-9-25
得分:0 
case 7: 后面的break;少了一个}
/////////////////
#define maxsize 100
#include<stdio.h>
#include<iostream.h>
typedef int elemtype;
typedef struct
{
elemtype data[maxsize];
int length;
}sqlist;

void initlist(sqlist &l)
{
l.length =0;
}
//////////////////////int data[maxsize];
void creatsqlist(sqlist &l,int n)
{
int i;//要判断n是否大于maxsize
for(i=0;i<n;i++)
cin>>l.data[i];////////////////////
l.length =n;
fflush(stdin);
}

void output(sqlist l)//&l
{
int i;
for(i=0;i<l.length ;i++)
cout<<l.data[i]<<endl;///////////////////////////
}

int isempty(sqlist l)//&l

{
if(l.length ==0)return 1;
else return 0;
}

int getelem(sqlist l,int i)//&l
{
if(i<0||i>=l.length ) return -1;
else return l.data [i];
}

int locateelem(sqlist l,elemtype x))//&l
{
int k=0;
while(k<l.length && l.data [k]!=x)
k++;
if(k<l.length)return k;
else return -1;
}

int insert(sqlist &l,elemtype x,int i)
{
int k;
if(i<0||i>l.length ||l.length==maxsize)
return 0;   
else
{for(k=l.length ;k>=i;k--)
l.data [k]=l.data [k-1];
l.data [i]=x;
l.length =l.length +1;
}
return 1;
}

int DELETE(sqlist &l,int i)
{int k;
if(i<0||i>=l.length )
return 0;
else
{for(k=i;k<l.length ;k++)
l.data [k]=l.data [k+1];
l.length --;
}
return 1;
}

//ok
void clear(sqlist &l)
{
    initlist(l);
}

void margelist(sqlist la,sqlist lb,sqlist &lc))//&la,&lb
{
    int i,j,k;
    i=j=k=0;
    while(i<la.length &&j<lb.length )
        if(la.data [i]<lb.data [j])
            lc.data [k++]=la.data [i++];
        else if(la.data [i]>lb.data [j])
            lc.data [k++]=lb.data [j++];
        else
        {lc.data [k++]=lb.data [j++];
        i++;
        }
        while (i<la.length )
            lc.data [k++]=la.data [i++];
        while(j<lb.length )
            lc.data [k++]=la.data [j++];
        lc.length =k;
}

//ok
void output()
{
    int i;
    for(i=0;i<10;i++)
        cout<<" ";
    for(i=0;i<32;i++)
        cout<<"*"<<endl;
}

void mainpp()
{
    int i;
//output();
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"1.建立一个顺序表"<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"2.输出一个顺序表  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"3.在顺序表中查找  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"4.向顺序表中插入一个元素  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"5.删除顺序表中的一个元素  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"6.从顺序表中取出一个元素  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"7.将两个顺序表合并  "<<"*"<<endl;
    for(i=0;i<10;i++) cout<<" ";cout<<"*"<<"0.退                  出 "<<"*"<<endl;
    for(i=0;i<8;i++) cout<<" ";cout<<"*"<<endl;
//output();
}

//ok

void main()
{
    int n,i,k=1,m,x;
    sqlist l,la,lc;
    initlist (l);
    mainpp();
    while(k)
    {cout<<"请选择0--7:  "<<endl;
    cin>>m;
    getchar();
   
    switch(m)
    {
    case 0: return;
        case 1:{
        cout<<"输入元素值,构成顺序表:"<<endl;
        cout<<"请输入顺序表元素的个数:";
        cin>>n;
        creatsqlist(l,n);
        output(l);
        break;
           }
    case 2: output(l);cout<<endl;break;
    case 3:{
        cout<<"请输入要查找的元素值  :";
        cin>>x;
        k=locateelem(l,x);
        cout<<"要查找的元素的定位:"<<endl;
        break;
           }
    case 4:{
        cout<<"输入要插入元素的位置及其值:";
        fflush(stdin);
        cin>>i;
        cin>>x;
        insert(l,x,i);
        output(l);
        cout<<endl;
        break;
           }
    case 5:
        {
            cout<<"输入要删除元素的位置:";
            fflush(stdin);
            cin>>i;
            output(l);
            break;
        }
    case 6:
        {
            cout<<"请输入要取出的元素的序号:";
            fflush(stdin);
            cin>>i;
            k=getelem(l,i);
            cout<<" 取出的第"<<i<<"个元素的序号:";
            break;
        }
    case 7:{
        initlist(la);
        cout<<" 请输入第2个顺序表元素的个数:";
        cin>>m;
        creatsqlist(la,m);
        output(la);
        margelist(l,la,lc);
        cout<<"输出合并后的顺序表中的元素 :"<<endl;
        output(lc);
        break;}////////////////////////////////////
    default :return;
           }
        cout<<" 继续运行吗Y(1)/N(0) :";
            cin>>k;
        if(!k) return ;
    }

    }
试试看!我的机子不能运行C++,你自己可以调试一下。大体上是没什么问题,只是有些小地方疏忽。

2012-10-10 15:56
unix8
Rank: 1
等 级:新手上路
帖 子:3
专家分:5
注 册:2012-10-10
得分:0 
unix论坛,Linux论坛,C/C++编程学习地方,欢迎新手朋友们一起来交流,共同进步。
2012-10-10 17:52



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




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

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