数据结构(严蔚敏版)1、线性表的基本操作-C++实现

直接上代码:

#include<iostream>
using namespace std;
int const LIST_INIT_SIZE=100;
typedef struct {
	int e;                   //线性表的值
}Polynomial;
class Sqlist {
private:
	Polynomial* L;
	int length;
public:
	Sqlist();                                //初始化线性表
	~Sqlist();                               //销毁线性表
	void CreatList();
	void ClearList();                       //将线性表置为空
	bool ListEmpty();                       //判断线性表是否为空
	int ListLength();                      //返回元素的长度
	void GetElem(int i,int &e);                   //用e返回第i个数据元素的值
	void PriorElem(int cur_e, int& pre_e);           //用pre返回L中元素cur_e的前驱
	void NextElem(int cur_e, int& next_e);             //用next_e返回元素cur_e的后继
	void ListinSert(int i, int e);                     //在L中第i个位置之前插入新的数据元素e
	void ListDelete(int i, int& e);                      //在L中删除第i个位置的元素并用e返回
	void print();                                        //打印L中的内容
};
Sqlist::Sqlist() {										 //初始化线性表
	L = new Polynomial[LIST_INIT_SIZE];
	length = 0;
}
Sqlist::~Sqlist() {										//销毁线性表
	delete[] L;
	length = 0;
}
void Sqlist::CreatList() {
	for (int i = 1; i <= 10; i++) {
		L[i].e = i;
		length++;
	}
}
void Sqlist::ClearList() {								//将线性表置为空
	length = 0;
}
bool Sqlist::ListEmpty() {								//判断线性表是否为空
	if (length == 0) {
		return true;
	}
	else {
		return false;
	}
}
int Sqlist::ListLength() {								//返回元素的长度
	return length;
}
void Sqlist::GetElem(int i, int& e) {					//用e返回第i个数据元素的值
	if (i < 1 || i > length) {
		cout << "ERROR PLACE" << endl;
		return;
	}
	e = L[i].e;
}
void Sqlist::PriorElem(int cur_e, int& pre_e) {			//用pre返回L中元素cur_e的前驱
	int flag = 0;
	for (int i = 0; i < length; i++) {
		if (L[i].e == cur_e) {
			flag--;
			break;
		}
		flag++;
	}
	pre_e = L[flag].e;
}
void Sqlist::NextElem(int cur_e, int& next_e) {			//用next_e返回元素cur_e的后继
	int flag = 0;
	for (int i = 0; i < length; i++) {
		if (L[i].e == cur_e) {
			flag++;
			break;
		}
		flag++;
	}
	next_e = L[flag].e;
}
void Sqlist::ListinSert(int i, int e) {                //在L中第i个位置之前插入新的数据元素e
	if (i < 1 || i >(length + 1)) {
		cout << "ERROR PLACE" << endl;
		return;
	}
	else if (length == LIST_INIT_SIZE) {
		cout << "The list is full" << endl;
		return;
	}
	else{
		for (int j = length + 1; j > i; j--) {
			L[j].e = L[j - 1].e;
		}
		L[i].e = e;
		length++;
		cout << "Insert Successful" << endl;
	}
}
void Sqlist::ListDelete(int i, int& e) {				//在L中删除第i个位置的元素并用e返回
	if (i < 1 || i > length) {
		cout << "ERROR PLACE" << endl;
		return;
	}
	else if (ListEmpty()) {
		cout << "NULL LIST" << endl;
		return;
	}
	else {
		e = L[i].e;
		for (int j = i; j <= length; j++) {
			L[j].e = L[j + 1].e;
		}
		cout << "DELETE SUCCESSFUL" << endl;
		length--;
	}
}
void Sqlist::print() {                                 //打印线性表中的值
	if (ListEmpty()) {
		cout << "NULL LIST" << endl;
		return;
	}
	else {
		for (int i = 1; i <= length; i++) {
			cout << L[i].e << " ";
		}
		cout << endl;
	}
}
void implement() {
	Sqlist s;
	s.CreatList();                  //创建一个线性表
	s.print();                      //打印创建的线性表
	int e1 = 0;
	s.GetElem(3, e1);               //用e1返回位置3处的线性表
	cout << e1 << endl;
	s.ListinSert(10, 11);           //在位置10处插入11
	s.print();
	s.ListDelete(10, e1);           //删除位置10处的值
	s.print();                  
	s.NextElem(5, e1);            //用e1返回位置5的后继元素
	cout << e1 << endl;
	s.PriorElem(5, e1);           //用e1返回5的前驱元素
	cout << e1 << endl;
}
int main() {
	implement();
}

代码运行结果如下图:

 

 ps:哪里有问题的话欢迎指正,打算尝试把严蔚敏版的书上算法都用C++代码实现一下

#define list_size 10 #define increment 5 #define ok 1 #include<stdlib.h> #include<stdio.h> #include<string.h> typedef struct{ int *elem; int length; int listsize;}sqlist; int initlist(sqlist &L)//构造一个空的线性表 { L.elem=(int *)malloc(list_size*sizeof(int)); if(!L.elem) printf("申请空间失败\n"); L.length=0; L.listsize=list_size; return ok; } int listinsert( sqlist &L, int i, int e )//插入 { int *p,*q,*newbase; if(i<1||i>L.length+1) printf("位置不合法\n"); if(L.length>=L.listsize) {newbase=(int *)realloc(L.elem,(L.listsize+increment)*sizeof(int));//扩容 if(!newbase) printf("扩容失败\n"); L.listsize+=increment;} q=&(L.elem[i-1]);// q 指示插入位置 for(p=&(L.elem[L.length-1]);p>=q;--p) *(p+1)=*p;// 插入位置及之后的元素右移 *q=e; // 插入e ++L.length;// 表长增1 return ok; } int ListDelete(sqlist &L, int i, int &e) //删除数据 { if ((i < 1) || (i > L.length)) printf("位置不合法\n"); int *p=&(L.elem[i-1]); // p 为被删除元素的位置 e = *p; // 被删除元素的值赋给 e int *q = L.elem+L.length-1; // 表尾元素的位置 for (++p; p <= q; ++p) *(p-1) = *p; // 被删除元素之后的元素左移 --L.length; // 表长减1 return ok; } int Listlength(sqlist L) //长度 { int *p=L.elem; //判断线形表是否存在 while(p) { return (L.length); } } int GetElem(sqlist L, int i,int &e) //取元素 { if(i<1 || i>L.length) printf("不存在此元素\n"); else { e=L.elem[i-1]; return e; } } void MergeList(sqlist La, sqlist Lb, sqlist &Lc;)//将非递减的有序表 La 和 Lb 归并为 Lc { initlist(Lc); // 构造空的线性表 Lc int i ,j ;i=j= 1; int k = 0; int La_len = Listlength(La); int Lb_len = Listlength(Lb); int ai,bj; i= j = 1, k = 0; GetElem(La, i, ai); GetElem(Lb, j, bj); if (ai <= bj) // 将 ai 插入到 Lc 中 { listinsert(Lc, ++k, ai); ++i; } else { // 将 bj 插入到 Lc 中 listinsert(Lc, ++k, bj); ++j; } while (i <= La_len) // 当La不空时 { GetElem(La, i++, ai); listinsert(Lc, ++k, ai); } // 插入 La 表中剩余元素 while (j <= Lb_len)// 当Lb不空时 { GetElem(Lb, j++, bj); listinsert(Lc, ++k, bj); } // 插入 Lb 表中剩余元素 } void printlist(sqlist &L)//打印 { int i; printf("\n$$$$$$$$$$$$$$$$$"); printf("\n顺序表的元素为:\n"); for(i=0;i<L.length;i++) printf("%d ",L.elem[i]); printf("\n$$$$$$$$$$$$$$$$$\n"); return; } main( ) { int i,j,n1,n2,e; sqlist La,Lb,Lc; initlist(La); printf("请输入顺序表La长度:"); scanf("%d",&La;.length); printf("请输入顺序表La的元素:"); for(n1=0;n1<La.length;n1++) scanf("%d",&La;.elem[n1]); printlist(La); printf("\n"); printf("请输入插入元素的位置:"); scanf("%d",&i); printf("请输入新元素:"); scanf( "%d", &e); listinsert(La,i,e ); printlist(La); printf("请输入删除第几个元素\n"); scanf("%d",&j); ListDelete(La,j,e); printlist(La); initlist(Lb); printf("请输入顺序表Lb长度:"); scanf("%d",&Lb;.length); printf("请输入顺序表Lb的元素:"); for(n2=0;n2<Lb.length;n2++) scanf("%d",&Lb;.elem[n2]); printlist(Lb); printf("合并\n"); initlist(Lc); MergeList(La,Lb,Lc); printlist(Lc); return 0; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值