#include <iostream>
using namespace std;
#define MaxSize 100 //定义线性表的最大长度
typedef struct Sqlist {
int data[MaxSize];
int length;
}Sqlist;
//初始化
void Init(Sqlist& L) {
L.length = 0;
}
//插入操作:在表中第i个位置上插入x
void Insert(Sqlist& L, int i, int x) {
if (i<1 || i>L.length + 1 || L.length >= MaxSize) {
cout << x << " 插入失败" << endl;
return;
}
for (int j = L.length; j >= i; j--) { //第i个及以后的元素后移
L.data[j] = L.data[j - 1];
}
L.data[i - 1] = x;
L.length++;
}
bool Del_s_t(Sqlist & L, int s, int t) {
//删除有序表L中在给定值s与t之间的所有元素
int i, k = 0;
if (s >= t || L.length == 0)
return false;
for (i = 0; i < L.length; i++) {
if (L.data[i] >= s&&L.data[i] <= t)
k++;
else
L.data[i - k] = L.data[i];
}
L.length-= k;
return true;
}
//遍历操作
void PrintList(Sqlist L) {
cout << "L: ";
for (int i = 0; i < L.length; i++) {
cout << L.data[i] << " ";
}
cout << endl;
}
int main() {
Sqlist L;
Init(L);
Insert(L,1,8);
Insert(L,2,5);
Insert(L,3,4);
Insert(L,4,7);
Insert(L,5,3);
Insert(L,6,1);
Insert(L,7,2);
Insert(L,8,6);
int s, t;
cout << "请输入s和t的值:";
cin >> s >> t;
if (!Del_s_t(L, s, t))
cout << "出错";
else {
cout << "删除后的数组为";
PrintList(L);
cout << endl;
}
return 0;
}