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

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

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

目录

移除数组

思路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--];}}

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

相关文章:

  • 《智能网联汽车 自动驾驶系统设计运行条件》 GB/T 45312-2025——解读
  • 04.three官方示例+编辑器+AI快速学习webgl_animation_skinning_additive_blending
  • 黑马k8s(三)
  • 【js基础笔记] - 包含es6 类的使用
  • 实战项目4(05)
  • MATLAB中矩阵和数组的区别
  • 05.three官方示例+编辑器+AI快速学习three.js webgl - animation - skinning - ik
  • Python Bug 修复案例分析:多线程数据竞争引发的bug 两种修复方法
  • HTTP/1.1 host虚拟主机详解
  • jsAPI
  • MySQL 索引(二)
  • 点和体素哪个好
  • JavaEE--文件操作和IO
  • 【计算机网络】NAT技术、内网穿透与代理服务器全解析:原理、应用及实践
  • 用C语言实现的——一个支持完整增删查改功能的二叉排序树BST管理系统,通过控制台实现用户与数据结构的交互操作。
  • 实战项目3(04)
  • TypeScript 环境搭建
  • 嵌入式硬件篇---TOF|PID
  • 《智能网联汽车 自动驾驶系统通用技术要求》 GB/T 44721-2024——解读
  • LC-3 中常见指令
  • 今天北京白天气温超30℃,晚间为何下冰雹?
  • 福建厦门市副市长、市公安局局长陈育煌出任吉林省公安厅厅长
  • 支持企业增强战略敏捷更好发展,上海市领导密集走访外贸外资企业
  • 专访|日本驻华大使金杉宪治:对美、对华外交必须在保持平衡的基础上稳步推进
  • 泽连斯基:乌克兰已做好与俄罗斯举行会谈的准备
  • 家电维修担心遇“李鬼”?上海推动“物业+专业服务”进社区