删除线性表a中第i个元素起的k个元素
代码如下:
#include<stdio.h>
#include<stdlib.h>
#define N 999
typedef struct
{
int data[N];
int Len;
}Arr;
void Create(Arr *L,int n);
void Output(Arr *L);
void Delet(Arr *L,int i,int k);
int main()
{
Arr L;
int m = 0;
int i,k;
printf("请输入数组长度:\n");
scanf("%d",&m);
L.Len = m - 1;
Create(&L,m);
printf("请输入删除位置:\n");
scanf("%d",&i);
printf("请输入删除元素个数:\n");
scanf("%d",&k);
Delet(&L,i,k);
printf("删除后结果:\n");
Output(&L);
return 0;
}
void Create(Arr *L,int n)
{
int i;
printf("请输入元素:\n");
for(i = 0;i <= n-1;i++)
{
scanf("%d",&L->data[i]);
}
}
void Output(Arr *L)
{
int i;
for(i = 0;i <= L->Len;i++)
{
printf("%d ",L->data[i]);
}
printf("\n");
}
void Delet(Arr *L,int i,int k)
{
int j;
if((i < 1)||(i > L->Len+1 ))
{
printf("Error!");
}
for(j = i;j <= L->Len;j++)
{
L->data[j-1] = L->data[j + k-1];
}
L->Len = L->Len-k;
}