PTA 顺序表的插入操作 (顺序表 函数)

顺序表的插入操作 (10 分)

本题要求实现一个函数,在顺序表的第i个位置插入一个新的数据元素e,插入成功后顺序表的长度加1,函数返回值为1;插入失败函数返回值为0;

函数接口定义:

int ListInsert(SqList &L,int i,ElemType e);

其中SqList结构定义如下:

typedef struct{
	ElemType *elem;
	int length;
 }SqList;
 

裁判测试程序样例:

#include 
#include 
#define MAXSIZE 5
typedef int ElemType;
typedef struct{
	ElemType *elem;
	int length;
 }SqList;
void InitList(SqList &L);/*细节在此不表*/
int ListInsert(SqList &L,int i,ElemType e);
int main()
{
	SqList L;
	InitList(L);
	ElemType e;
	int i;
	scanf("%d%d",&i,&e);
	int result=ListInsert(L,i,e);
	if(result==0){
		printf("Insertion Error.The value of i is unlawful or the storage space is full!");	
	}else if(result==1){
		printf("Insertion Success.The elements of the SequenceList L are:");	
		for(int j=0;j

输入格式:

输入数据有1行,首先给出以-1结束的顺序表元素值(不超过100个,-1不属于顺序表元素),然后是插入位置和被插入元素值。所有数据之间用空格分隔。

输入样例:

2 6 4 -1 2 100

输出样例:

Insertion Success.The elements of the SequenceList L are: 2 100 6 4

【代码】
int ListInsert(SqList &L, int i, ElemType e)
{
	if (i >= 0 && i <= L.length+1 && (L.length + 1) <= MAXSIZE)
	{
		for (int j = L.length-1; j >= i - 1; j--)
			L.elem[j + 1] = L.elem[j];
		L.elem[i - 1] = e;
		L.length++;
		return 1;
	}
	return 0;
}
【解析】

在第一个if的判断语句中,应是 i <= L.length+1,做题的时候写的是 i <= L.length,所以导致一个测试点一直错。

你可能感兴趣的:(PTA 顺序表的插入操作 (顺序表 函数))