qq_34324657
qq_34324657
2016-04-24 08:48
采纳率: 25%
浏览 1.6k
已采纳

数据结构 算法如何编译运行··跪求各位路过的大神帮帮忙啊

#include
#include

#define ERROR 0
#define OK 1

typedef int Status;
typedef int ElemType;//顺序表测试用

const int MaxSize=100; //100只是示例性的数据,可以根据实际问题具体定义
const int Increasement=10;

typedef struct{
ElemType *elem;
int length;
int listsize;
}SeqList;

Status InitList(SeqList &a,int n=MaxSize)
{//初始化线性表
if(n<=0)
n=MaxSize;
a.elem =(ElemType *)malloc(n*sizeof(ElemType));
if(a.elem ==NULL)
exit(ERROR);
a.length =0;
a.listsize =n;
return OK;
}
Status Deletek(SeqList &a,int i,int k) {//从顺序存储结构的线性表a中删除第i个元素起的k个元素??//注意i的编号从0开始??
int j;
if(ia.length-1||ka.length-i) return ERROR; for(j=0;j<=k;j++)
a.elem[j+i]=a.elem[j+i+k]; a.length=a.length-k; return OK;

}

void main()
{
SeqList La;
ElemType data;

printf("输入顺序表La的元素值:\n");
for(int i=1;i<=10;i++)
{
    scanf("%d",&data);

}


InitList(La,10);
Deletek(La,3,5);

}好像main函数有问题,但我不会改

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

2条回答 默认 最新

  • qq423399099
    小灸舞 2016-04-24 09:30
    已采纳

    要先InitList然后输入元素,删除元素的时候后面的依次移位上来

     #include<iostream>
    using namespace std;
    #define ERROR 0
    #define OK 1
    typedef int Status;
    typedef int ElemType;//顺序表测试用
    const int MaxSize=100; //100只是示例性的数据,可以根据实际问题具体定义
    const int Increasement=10;
    typedef struct{
        ElemType *elem;
        int length;
        int listsize;
    }SeqList;
    Status InitList(SeqList &a,int n=MaxSize)
    {//初始化线性表 
        if(n<=0)
            n=MaxSize;
        a.elem =(ElemType *)malloc(n*sizeof(ElemType));
        if(a.elem ==NULL)
            exit(ERROR);
        a.length =0;
        a.listsize =n;
        return OK;
    }
    Status Deletek(SeqList &a,int i,int k) {//从顺序存储结构的线性表a中删除第i个元素起的k个元素??//注意i的编号从0开始??
        int j;
        if(i>=a.length-1||k>=a.length-i) 
            return ERROR; 
        for(j=i+k;j<=a.length;j++)
        {
            a.elem[i++] = a.elem[j];
        }
        a.length=a.length-k; 
        return OK;
    }
    void main()
    {
        SeqList La;
        ElemType data;
        InitList(La,10);
        printf("输入顺序表La的元素值:\n");
        for(int i=1;i<=10;i++)
        {
            scanf("%d",&data);
            La.elem[i - 1] = data;
            La.length++;
        }
        Deletek(La,3,5);
        printf("删除后元素值:\n");
        for(int i=0;i<La.length;i++)
        {
            printf("%d ", La.elem[i]);
        }
        printf("\n");
    }
    

    图片说明

    点赞 评论
  • qq_34324657
    qq_34324657 2016-04-24 13:25

    谢谢大神出手相救,感激不尽呐!!!!!

    点赞 评论

相关推荐