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;
}
顺序表满:
往第一个位置插:
往最后一个位置插:
往中间插: