2.5、元素 x 插入递增有序的顺序表

2.4、求顺序表中的最大值和次大值

2.5、元素 x 插入递增有序的顺序表

2.6、合并两个递增顺序表 / 单链表

2.7、求俩递增单链表的交集单链表

/************************************************************
* Windows 10下,Dev-C++ 6.6、Visual Studio 2019 中测试通过	*
*															*
* @file		习题2.5.c										*
*															*
* @brief	习题2.5											*
*			设顺序表中数据元素值递增有序。					*
*			编写算法,将数据元素 x 插到表中					*
*			适当的位置,并保持顺序表的有序性				*
*															*
* @author	CSDN@洛必不达法则								*
*															*
* @date		2021-10-17										*
*************************************************************/

#define _CRT_SECURE_NO_WARNINGS		// VS2019中 scanf 被认为是不安全的,需要加上该宏才能使用
#include <stdio.h>
#include <stdlib.h>

/**
* @brief	定义顺序表结构体
*/
typedef struct
{
	int* data;		// 存储数据元素的一段内存
	int last;		// 最后一个元素的下标
	int maxsize;	// 最大容量
}SeqList;

/**
* @brief	初始化顺序表
* @param maxsize	顺序表的容量
* @return	初始化成功的顺序表地址
*/
SeqList* InitSeqList(int maxsize)
{
	SeqList* pList = (SeqList*)malloc(sizeof(SeqList));
	if (!pList)
	{
		printf("内存申请失败!\n");
		return NULL;
	}
	pList->data = (int*)malloc(sizeof(int) * maxsize);
	if (!pList->data)
	{
		printf("内存申请失败!\n");
		return NULL;
	}
	pList->maxsize = maxsize;
	pList->last = -1;
	return pList;
}

/**
* @brief	创建顺序表
* @return	创建的顺序表的地址
*/
SeqList* CreateSeqList()
{
	int maxsize = 0;
	int data = 0;
	printf("设置顺序表的容量:");
	scanf("%d", &maxsize);
	SeqList* pList = InitSeqList(maxsize);
	printf("递增输入顺序表的数据(输入任意字母字符结束):\n");
	while (pList->last < pList->maxsize - 1)
	{
		if (!scanf("%d", &data))
			break;
		pList->data[++pList->last] = data;
	}
	return pList;
}


/**
* @brief	遍历打印顺序表表数据
* @param pList	需要遍历的顺序表
*/
void PrintSeqList(SeqList* pList)
{
	for (int i = 0; i <= pList->last; i++)
	{
		printf("%d  ", pList->data[i]);
	}
	printf("\n");
}

/**
* @brief	将数据插入递增有序的顺序表
* @param pList	需要插入的顺序表
* @param nData  需要插入的数据
*/
void InsertList(SeqList* pList, int nData)
{
	// 顺序表满
	if (pList->last == pList->maxsize - 1)
	{
		printf("顺序表已满,无法插入!\n");
		return;
	}
	// 比顺序表第一个值还小,插到第一个
	if (nData <= pList->data[0])
	{
		for (int j = pList->last; j >= 0; j--)
		{
			pList->data[j + 1] = pList->data[j];
		}
		pList->data[0] = nData;
		pList->last++;
		return;
	} 
	// 正常往中间插 或,比顺序表最后一个值还大,加到最后一个
	for (int i = 0; i <= pList->last; i++)
	{
		if (nData >= pList->data[i] && (nData <= pList->data[i + 1] ||  i == pList->last))
		{
			for (int j = pList->last; j > i; j--)
			{
				pList->data[j + 1] = pList->data[j];
			}
			pList->data[i + 1] = nData;
			pList->last++;
			return;
		}
	}
}

int main()
{
	printf("\t********* 习题2.5 *********\n");
	SeqList* pList = CreateSeqList();

	printf("插入前顺序表:\n");
	PrintSeqList(pList);

	int x = 0;
	printf("输入要插入的数据:");
	setbuf(stdin, NULL);
	scanf("%d", &x);
	InsertList(pList, x);

	printf("插入后顺序表:\n");
	PrintSeqList(pList);

	return 0;
}

顺序表满:

往第一个位置插:

往最后一个位置插:

 往中间插:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值