【数据结构与算法】第2课—数据结构之顺序表

文章目录

  • [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. 顺序表

  • 顺序表是用一段物理地址连续的存储单元依次存储数据数据元素的线性结构,一般情况下采用数组存储
  • 顺序表的底层结构是数组,对数组进行封装,实现常用的增删改查等接口
  • 顺序表又分为静态顺序表和动态顺序表
  • 由于静态顺序表的内存大小固定,因此常常使用的是动态顺序表

2.1 动态顺序表初始化


2.2 尾插





2.3 头插




2.4 尾删



2.5 头删



2.6 查找数


2.7 指定位置插入数据



2.8 指定位置删除数据



2.9 销毁


3. 练习

3.1 练习1---移除元素


  • 举个简单的例子

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---删除有序数组中的重复项


  • 举个简单的例子

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---合并有序数组


  • 拿思路2举个简单的例子

  • 另外还需要考虑一个问题


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--];
}
相关推荐
别NULL2 小时前
机试题——疯长的草
数据结构·c++·算法
ZSYP-S4 小时前
Day 15:Spring 框架基础
java·开发语言·数据结构·后端·spring
唐叔在学习4 小时前
【唐叔学算法】第21天:超越比较-计数排序、桶排序与基数排序的Java实践及性能剖析
数据结构·算法·排序算法
ALISHENGYA4 小时前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(switch语句)
数据结构·算法
武昌库里写JAVA7 小时前
浅谈怎样系统的准备前端面试
数据结构·vue.js·spring boot·算法·课程设计
S-X-S7 小时前
代码随想录刷题-数组
数据结构·算法
l138494274517 小时前
每日一题(4)
java·数据结构·算法
kyrie_sakura7 小时前
c++数据结构算法复习基础--13--基数算法
数据结构·c++·算法
XWXnb68 小时前
数据结构:顺序表
数据结构·算法
橘颂TA8 小时前
【C++】数据结构 顺序表的实现(详解)
开发语言·数据结构·c++·算法