实验一线性表的基本操作实现及其应用

一、实验目的

1、熟练掌握线性表的结构特点,掌握顺序表的基本操作。

2、巩固 C++相关的程序设计方法与技术。

3、学会使用顺序表解决实际问题。

二、实验内容

1、顺序表的建立与操作实现 建立 n 个元素的顺序表(n 的大小和表里数据自己确定),实现相关的操作:输出,插 入,删除,查找等功能。编写完整程序实现,程序语言不限定,使用技术形式不定。

2、实际问题的解决(*) 使用顺序表来实现约瑟夫环问题。

三、代码实现

#include
   
   
    
    
using namespace std;
const int X = 10;
template
    
    
     
     
class seqlist
{
public:
	seqlist()     
	{
		length = 0;
	};
	seqlist(A b[], int n);
	~seqlist() {};
	int Length()
	{
		return length;
	};
	A get(int i);
	int locate(A y);
	void insert(int i, A y);
	A Delete(int i);
	void printlist();
private:
	A data[X];
	int length;
};
template
     
     
      
      
seqlist
      
      ::seqlist(A b[], int n)
{
	if (n>X)throw"参数非法";
	for (int i = 0; i
       
       
         A seqlist 
       
      
      ::get(int i)
{
	if (i<1 && i>length)throw"查找位置非法";
	else return data[i - 1];
};
template
       
       
         int seqlist 
       
      
      ::locate(A y)
{
	for (int i = 0; i
       
       
         void seqlist 
       
      
      ::insert(int i, A y)
{
	if (length >= X)throw"上溢";
	if (i<1 || i>length+1)throw"位置";
	for (int j = length; j >= i; j--)
		data[j] = data[j - 1];
	data[i - 1] = y;
	length++;
};
template
       
       
         A seqlist 
       
      
      ::Delete(int i)
{
	if (length == 0)throw"下溢";
	if (i<1 || i>length)throw"位置";
	x = data[i - 1];
	for (int j = i; j
       
       
         void seqlist 
       
      
      ::printlist()
{
	for (int i = 0; i
       
       
         scorelist(score, 6); scorelist.printlist(); cout << "\n" << endl; scorelist.insert(7, 5); scorelist.printlist(); cout << "\n" << endl; return 0; } 
       
     
     
    
    
   
   
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值