数据结构--线性表的顺序表示(顺序表)

线性表分两种,一种是顺序表,一种是链表。

先介绍第一种顺序表:

#include<stdio.h>
#include<stdlib.h>

typedef struct {
	int *data;
	int length;											//这个是顺序表中现有的元素个数。
	int maxsize;										//这个是顺序表中可容纳的最大的元素个数。
}sqlist;





sqlist creat(sqlist &l,int maxnum){						//创建顺序表

	l.maxsize = maxnum;
	l.data = new int[l.maxsize];
	l.length = 0;

	return l;
}




bool insert(sqlist &l,int data,int position){			//插入元素

	if(position<=0 && position >=l.maxsize){			//判断插入位置是否在范围内
		return false;
	}

	if(l.length >= l.maxsize){							//判断是否容量已满
		return false;
	}

	for(int i=l.length; i>=position; i--){				//把相应位置的元素依次向后移一位。
		l.data[i]=l.data[i-1];							//这里很容易出错,注意i的值。
	}

	l.data[position-1]=data;
	l.length++;

	return true;
}



void output(sqlist &l){									//输出相应元素。

	for(int i=0; i<l.length; i++){
		printf("%d\n",l.data[i]);
	}
}



int main(){

	sqlist l = creat(l,10);
	for(int i=0; i<5; i++)
		insert(l,i,1);
	output(l);

	return 0;
}


  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值