📄 main2-8.cpp
字号:
// main2-8.cpp 检验bo2-8.cpp的主程序
#include"c1.h"
typedef int ElemType; // 也可以定义ElemType为实型或双精度型
#include"c2-1.h"
#include"bo2-8.cpp"
void visit(ElemType &c) // ListTraverse()调用的函数(类型要一致)
{
cout<<c<<' ';
}
void main()
{
SqList L;
ElemType d,e;
Status i;
int n;
printf("按非降序建立n个元素的线性表L,请输入元素个数n: ");
scanf("%d",&n);
CreatAscend(L,n);
printf("依次输出L的元素:");
ListTraverse(L,visit);
InsertAscend(L,10); // 按非降序插入元素10
printf("按非降序插入元素10后,线性表L为:");
ListTraverse(L,visit);
HeadInsert(L,12); // 在L的头部插入12
EndInsert(L,9); // 在L的尾部插入9
printf("在L的头部插入12,尾部插入9后,线性表L为:");
ListTraverse(L,visit);
printf("请输入要删除的元素的值: ");
cin>>e;
i=DeleteElem(L,e);
if(i)
cout<<"成功删除"<<e<<'!'<<endl;
else
cout<<"不存在元素"<<e<<'!'<<endl;
printf("线性表L为:");
ListTraverse(L,visit);
printf("请输入要取代的元素的序号 元素的新值: ");
cin>>n>>e;
ReplaceElem(L,n,e);
printf("线性表L为:");
ListTraverse(L,visit);
DestroyList(L);
printf("销毁L后,按非升序重新建立n个元素的线性表L,请输入元素个数n(>2):");
scanf("%d",&n);
CreatDescend(L,n);
printf("依次输出L的元素:");
ListTraverse(L,visit);
InsertDescend(L,10); // 按非升序插入元素10
printf("按非升序插入元素10后,线性表L为:");
ListTraverse(L,visit);
printf("请输入要删除的元素的值: ");
cin>>e;
i=DeleteElem(L,e);
if(i)
cout<<"成功删除"<<e<<'!'<<endl;
else
cout<<"不存在元素"<<e<<'!'<<endl;
printf("线性表L为:");
ListTraverse(L,visit);
DeleteFirst(L,e);
DeleteTail(L,d);
cout<<"删除表头元素"<<e<<"和表尾元素"<<d<<"后,线性表L为:"<<endl;
ListTraverse(L,visit);
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -