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 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器