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

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

#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条回答

  • 小灸舞 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");
    }
    

    图片说明

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!