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条)

报告相同问题?

悬赏问题

  • ¥15 umi接入sentry遇到问题
  • ¥15 HBuilderX打包H5网页,扫码模块无法使用
  • ¥15 Javascript跳转页面后,无法执行后面代码,如何解决?
  • ¥15 echarts绘制图表
  • ¥15 请教两个关于高德地图定位不准的技术问题
  • ¥15 根据企业名称 对照两个文件 样本筛选/匹配
  • ¥15 Linux环境下CA证书更新问题
  • ¥15 sqlserver语句提取结果以外数据
  • ¥60 微信小程序如何上传QQ聊天文件
  • ¥300 开发的系统遭到无良商家的破解,请问如何防止再次发生,并追回损失