文章目录
- [1. 线性表](#1. 线性表)
- [2. 顺序表](#2. 顺序表)
-
- [2.1 动态顺序表初始化](#2.1 动态顺序表初始化)
- [2.2 尾插](#2.2 尾插)
- [2.3 头插](#2.3 头插)
- [2.4 尾删](#2.4 尾删)
- [2.5 头删](#2.5 头删)
- [2.6 查找数](#2.6 查找数)
- [2.7 指定位置插入数据](#2.7 指定位置插入数据)
- [2.8 指定位置删除数据](#2.8 指定位置删除数据)
- [2.9 销毁](#2.9 销毁)
- [3. 练习](#3. 练习)
-
- [3.1 练习1---移除元素](#3.1 练习1—移除元素)
- [3.2 练习2---删除有序数组中的重复项](#3.2 练习2—删除有序数组中的重复项)
- [3.3 练习3---合并有序数组](#3.3 练习3—合并有序数组)
1. 线性表
- 线性表:n个具有相同特性的数据元素的有限序列,常见的线性表有:顺序表、链表、栈、队列和字符串等
- 线性表在逻辑结构上是一条连续的直线,在物理结构上不一定是连续的
- 线性表在物理上存储时,通常以数组和链式结构的形式进行存储
2. 顺序表
- 顺序表是用一段物理地址连续的存储单元依次存储数据数据元素的线性结构,一般情况下采用数组存储
- 顺序表的底层结构是数组,对数组进行封装,实现常用的增删改查等接口
- 顺序表又分为静态顺序表和动态顺序表
- 由于静态顺序表的内存大小固定,因此常常使用的是动态顺序表
data:image/s3,"s3://crabby-images/06a96/06a967b2f3719863a4caf077db15eef896831ff8" alt=""
2.1 动态顺序表初始化
data:image/s3,"s3://crabby-images/e141f/e141f6b075d16cd74b561bb42020c5ccddd5ba44" alt=""
2.2 尾插
data:image/s3,"s3://crabby-images/7aee9/7aee92b87cb6fd7a857b775802788b2825fbdce3" alt=""
data:image/s3,"s3://crabby-images/4d462/4d462a6e4b146b160efe61bb3f7d10ddac72b5a9" alt=""
data:image/s3,"s3://crabby-images/ee186/ee1860efa2c315d277f14299d61d8ebb0a5278fc" alt=""
data:image/s3,"s3://crabby-images/d8e0b/d8e0bbe3f97f3ae0e6b462f63ca7f8a9cd4b83fb" alt=""
2.3 头插
data:image/s3,"s3://crabby-images/586a0/586a0051e3280d450587babc0c27a53dfb61a56e" alt=""
data:image/s3,"s3://crabby-images/d504b/d504ba11840be462cad900e95bcf23c28cd7ec80" alt=""
data:image/s3,"s3://crabby-images/992c8/992c864e76d70485c842c763986e27d076d1a47b" alt=""
2.4 尾删
data:image/s3,"s3://crabby-images/935e6/935e655d350d63cda0b84efe82175f211618826c" alt=""
data:image/s3,"s3://crabby-images/564a3/564a35e45987c960d7dca72393b50c9194b4f8d4" alt=""
2.5 头删
data:image/s3,"s3://crabby-images/ef504/ef504d9d0bedc924bc0b2ca6cfaa83ecffd907ca" alt=""
data:image/s3,"s3://crabby-images/3432a/3432a0c79409d0e14efea2d5e8bcf0fc5b926781" alt=""
2.6 查找数
data:image/s3,"s3://crabby-images/68152/6815214157d886bfded62aced22417264db5c73f" alt=""
2.7 指定位置插入数据
data:image/s3,"s3://crabby-images/020da/020daeb74f4cfac04e3f7b856335e8848b3e5b22" alt=""
data:image/s3,"s3://crabby-images/def53/def538c64d31d47725adf6a06ca60beb98257948" alt=""
2.8 指定位置删除数据
data:image/s3,"s3://crabby-images/84b93/84b93543ec0d38f9073cfc15ed19f25ba4a94d58" alt=""
data:image/s3,"s3://crabby-images/9b989/9b989f0ee4559a61b221f12dcc1273ae5eda632b" alt=""
2.9 销毁
data:image/s3,"s3://crabby-images/8e7df/8e7df26beb1cafd74d6991495fb7a34c028292c4" alt=""
data:image/s3,"s3://crabby-images/c1ed3/c1ed3ce004e8f4d282f7e3a9f0d500f0e959a8b4" alt=""
3. 练习
3.1 练习1---移除元素
data:image/s3,"s3://crabby-images/ba3bc/ba3bcf0feac571f07220988dbae4d17dedd3dd79" alt=""
- 举个简单的例子
data:image/s3,"s3://crabby-images/2b274/2b274eef819a5b2c3825f3ae54639d2758645278" alt=""
c
//练习1
//给定数组,移除等于val的数
//例如:nums[]={ 2, 2, 3, 3},val = 3;
//移除后:nums[]={ 2, 2};
int removeElement(int* nums, int numsSize, int val)
{
int src = 0;
int dst = 0;
while (src < numsSize)
{
if (nums[src] != val)
{
nums[dst] = nums[src];
dst++;
}
src++;
}
return dst;
}
3.2 练习2---删除有序数组中的重复项
data:image/s3,"s3://crabby-images/acf4f/acf4fd96b642cb615f431aa6a2fe4a49dafd87ec" alt=""
- 举个简单的例子
data:image/s3,"s3://crabby-images/1d075/1d0754f3da04690cf553af2af48baecfc9a21efe" alt=""
c
//练习2
//删除有序数组的重复项
int removeDuplicates(int* nums, int numsSize)
{
int dst = 0;
int src = dst + 1;
while (src < numsSize)
{
if (nums[src] != nums[dst])
{
dst++;
nums[dst] = nums[src];
src++;
}
else
src++;
}
return dst + 1;
}
//优化
int removeDuplicates(int* nums, int numsSize)
{
int dst = 0;
int src = dst + 1;
while (src < numsSize)
{
if (nums[src] != nums[dst])
{
dst++;
if (src != dst)
{
nums[dst] = nums[src];
}
}
src++;
}
return dst + 1;
}
3.3 练习3---合并有序数组
data:image/s3,"s3://crabby-images/336f9/336f9edfe511f7314b05e320167bbeda08c3e67d" alt=""
- 拿思路2举个简单的例子
data:image/s3,"s3://crabby-images/9cd47/9cd47acdf673d0fe83306746a2fab392802c5ad6" alt=""
- 另外还需要考虑一个问题
data:image/s3,"s3://crabby-images/ba2c8/ba2c83782a8c2dedb00f955dadee09b6f08d4976" alt=""
data:image/s3,"s3://crabby-images/8cdcd/8cdcd339bb5b8b586b87dfec78f91c1bda2dbe32" alt=""
c
//练习3:合并有序数组
void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n)
{
int src = m - 1;
int dst = n - 1;
int index = m + n - 1;
while (src >= 0 && dst >= 0)
{
if (nums1[src] > nums2[dst])
nums1[index--] = nums1[src--];
else
nums1[index--] = nums2[dst--];
}
//若nums2数组元素在src越界后还未全部放入
while (dst >= 0)
nums1[index--] = nums2[dst--];
}