当前位置: 首页 > java >正文

数据结构练习:顺序表题目

        今天我们来进行顺序表后面习题的练习

目录

移除数组

思路1:查找后进行删除

        思路2:新数组交换:

        思路3:双指针法:

删除重复项

合并两个有序数组


移除数组

 它的示例如下:

思路1:查找后进行删除

如下图所示,当我们输入4的时候,进行第一次查找删除的操作

当我们执行完所有的流程之后,

#include<stdio.h>
#include<assert.h>
#include<stdlib.h>
void delete(int r, int* arr, int size)
{int i = 0;if (r!=0){for (i = r - 1;i < size - 1;i++){arr[i] = arr[i + 1];}}}
int Find(int* arr,int size, int k)
{assert(arr);//遍历数组查找for (int i = 0;i <= size - 1;i++){if (k == arr[i]){//找到了return i + 1;}else{continue;}}return -1;//无效的下标表示没找到
}
int main()
{int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };int r=Find(arr, 10, 5);delete(r,arr,10);for (int i = 0;i <9;i++){printf("%d ", arr[i]);}return 0;
}

        思路2:新数组交换:

        思路:创建一个新的数组,当数组中的值不等于给定的值的时候将其赋值给新数组,然后将新数组的值赋值给旧数组

#include<stdio.h>
#include<assert.h>
#include<stdlib.h>
void delete( int* arr, int size,int k)
{int *temp=(int *)malloc(sizeof(int)*size);for (int i = 0,j=0;i < size;i++,j++){if (arr[i] != k){temp[j]=arr[i];}else{temp [j] =0 ;}}for (int i = 0;i < size;i++){arr[i] = temp[i];}}
int main()
{int arr[10] = { 3,3,4,5,2,1,8,4,5 ,6};delete(arr, 10, 5);for (int i = 0;i <9;i++){printf("%d ", arr[i]);}return 0;
}

        思路3:双指针法:

        思路:给定两个指针,分别为快指针和慢指针,慢指针在快指针遍历一次数组后向后移动一次。当快指针指向的值等于给定的值的时候,继续向后走;当不等于的时候,将快指针的数据赋值给慢指针,慢指针向后移动一格。

// 双指针
int removeElement(int* nums, int numsSize, int val) {// slow为左指针,是将要赋值的位置;fast为右指针,是要赋值的元素int slow = 0, fast = 0;while(fast < numsSize){// 若右指针元素不为val,它一定是输出数组中的元素,将右指针元素复制到左指针元素if(nums[fast] != val){nums[slow++] = nums[fast];}// 若右指针元素为val,它不为输出数组中的元素,左指针不动,右指针向后移动fast++;}return slow;
}

删除重复项

        

示例:

思路:双指针法。第一个变量和第二个变量分别指向起始位置和后一个位置。

l力扣官方题解:

int removeDuplicates(int* nums, int numsSize)
{int sec=0;int eoc=sec+1;while(sec<numsSize){if(nums[sec]!=nums[eoc]&&++sec!=eoc){nums[sec]=nums[eoc];eoc++;}sec++;}return sec+1;
}

合并两个有序数组

        思路1:先合并再排序

        思路2:空间换时间:创建新数组tmp,大小与nums大小相同,遍历两个数组的数据比较大小并放到tmp中

        思路3:从后往前比较大小,找大的

        L1和L3比较大小。当L3大的时候,将L3的数据赋值给L2,随后L2和 L3 分别向前移动一个位置;L1大的时候,L1 赋值给L3 ,L1和L3 向前移动一个位置。直到有一个越界了停止

        代码如下:

void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n) 
{int l1=m-1;int l2=n-1;int l3=m+n-1;while(l1>=0&&l2>=0){//比较大小,找大的if(nums1[l1]>nums2[l2]){nums1[l3--]=nums1[l1--];}else {nums1[l3--]=nums2[l2--];}}//要么l1越界,要么l2越界while(l2>=0){nums1[l3--]=nums2[l2--];}}

        本期博客就到这里了。接下来我们将学习数据结构中单链表的内容

http://www.xdnf.cn/news/5417.html

相关文章:

  • terraform云上实战(一):执行阿里云云助手命令
  • C++ string初始化、string赋值操作、string拼接操作
  • Celery 在分布式任务调度中的实现原理及 MQ 系统对比
  • GIF图像技术介绍
  • 隐马尔可夫模型(HMM)在彩票预测中的Java实现
  • OpenCV进阶操作:指纹验证、识别
  • 复现MAET的环境问题(自用)
  • Javascript基础语法
  • 【STM32开发】-单片机开发基础(以STM32F407为例)
  • SEO长尾关键词布局优化法则
  • 虚拟内存笔记(三)虚拟内存替换策略与机制
  • 前端项目打包部署流程j
  • 北大闰凯博士:热辐射输运问题蒙特卡罗模拟中的全局最优参考场方法
  • HTOL集成电路老化测试学习总结-20250510
  • Linux : 多线程【线程概念】
  • ssh -T git@github.com 测试失败解决方案:修改hosts文件
  • 计算机基础
  • 深入了解linux系统—— 自定义shell
  • 24、TypeScript:预言家之书——React 19 类型系统
  • MYSQL语句,索引,视图,存储过程,触发器(一)
  • 用 LVGL 打造苹果风格音量滑块:圆润无球,极简优雅
  • TCP/IP 模型每层的封装格式
  • C++ stl中的set、multiset、map、multimap的相关函数用法
  • SQL语句的优化
  • 学习和测试WebApi项目限制客户端ip访问接口(基于中间件)
  • Python httpx库终极指南
  • 端口号被占用怎么解决
  • 《Effective Python》第1章 Pythonic 思维详解——深入理解 Python 条件表达式(Conditional Expressions)
  • JAVA EE_网络原理_网络层
  • PowerShell 脚本中文乱码处理