leetCode - - - 数组

embedded/2024/10/15 18:52:52/

1.移动0(leetcode283)

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

请注意 ,必须在不复制数组的情况下原地对数组进行操作。

class Solution {public void moveZeroes(int[] nums) {int slow=0;for(int fast=0;fast<nums.length;fast++){if(nums[fast]!=0){nums[slow]=nums[fast];slow++;}}for(int i=slow;i<nums.length;i++){nums[i]=0;}}
}

2.颜色分类(leetcode75)

给定一个包含红色、白色和蓝色、共 n 个元素的数组 nums ,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。

我们使用整数 0、 1 和 2 分别表示红色、白色和蓝色。

必须在不使用库内置的 sort 函数的情况下解决这个问题。

class Solution {public void sortColors(int[] nums) {int left=0;int right=nums.length-1;int index=0;while(index<=right){int cur=nums[index];if(cur==0){swap(nums,index,left);//index不能再left的左边index++;left++;}if(cur==1){index++;}if(cur==2){swap(nums,index,right);right--;//这里没有index++;因为还不知道num[index]是多少,可能是0,还要往前交换}}}//交换public void swap(int[] nums,int i,int j){int tmp=nums[i];nums[i]=nums[j];nums[j]=tmp;}}

3.删除有序数组中的重复项目(leetcode26)

给你一个 非严格递增排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。

考虑 nums 的唯一元素的数量为 k ,你需要做以下事情确保你的题解可以被通过:

  • 更改数组 nums ,使 nums 的前 k 个元素包含唯一元素,并按照它们最初在 nums 中出现的顺序排列。nums 的其余元素与 nums 的大小不重要。
  • 返回 k 。

判题标准:

系统会用下面的代码来测试你的题解:

int[] nums = [...]; // 输入数组
int[] expectedNums = [...]; // 长度正确的期望答案int k = removeDuplicates(nums); // 调用assert k == expectedNums.length;
for (int i = 0; i < k; i++) {assert nums[i] == expectedNums[i];
}

如果所有断言都通过,那么您的题解将被 通过

class Solution {public int removeDuplicates(int[] nums) {//p用来放即将要存储的位置int p=0;//对数组元素进行遍历for(int i=0;i<nums.length;i++){if(i==0||nums[i]!=nums[i-1]){nums[p]=nums[i];p++;}}return p;}
}

4.合并两个有序数组(leetcode88)

给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。

请你 合并 nums2 到 nums1 中,使合并后的数组同样按 非递减顺序 排列。

注意:最终,合并后数组不应由函数返回,而是存储在数组 nums1 中。为了应对这种情况,nums1 的初始长度为 m + n,其中前 m 个元素表示应合并的元素,后 n 个元素为 0 ,应忽略。nums2 的长度为 n 。

class Solution {public void merge(int[] nums1, int m, int[] nums2, int n) {//设置三个索引,原来num1的末端,原来num2的末端,合并后num1的末端int i=m-1;int j=n-1;int cur=nums1.length-1;//num2中元素要全部合并到num1中while(j>=0 ){if(i>=0 &&nums1[i]>nums2[j]){nums1[cur]=nums1[i];cur--;i--;}else{nums1[cur]=nums2[j];cur--;j--;}}}
}

这道题解的很波折 ~~~~

终于明白了 o(╥﹏╥)o 


http://www.ppmy.cn/embedded/90854.html

相关文章

把销售额做到极致的摄影师都具备什么能力?

声明&#xff1a;此篇为 ai123.cn 原创文章&#xff0c;转载请标明出处链接&#xff1a;把销售额做到极致的摄影师都具备什么能力&#xff1f; | AI导航 ai123.cn 嘿&#xff0c;各位摄影师&#xff01;今天来和你们聊聊一个“神秘”的话题&#xff1a;如何借助AI的力量&#x…

AI智能对战,当当狸智能五子棋!多种玩法更有趣,全家人都能畅玩

大家好&#xff0c;我是狸狸&#xff0c;我一直喜欢能和孩子一起玩的益智桌游&#xff0c;今天给大家介绍一款非常棒的智能五子棋——不用手机 也无需棋子。 这款棋既支持双人对战&#xff0c;也可以一个人和AI玩&#xff0c;系统语音提示、自动判输赢。 它拥有13*13的AI超大棋…

关于netstat查不到映射端口的连接信息的原因

在宿主机上使用 netstat -ano 无法查到公网访问容器映射的端口连接信息&#xff0c;但可以查到内网IP访问容器映射端口的信息&#xff0c;而在容器中 netstat -ano 都可以查到&#xff0c;这是因为 Docker 的网络命名空间隔离和 NAT&#xff08;网络地址转换&#xff09;规则导…

JavaWeb-HTML

一、HTML&CSS&JavaSript的作用: 1.HTML主要用于网页为主体结构的搭建&#xff1b; 2.CSS主要用于页面元素的美化 3.JavaScript主要用于页面元素的动态处理; 二、HTML HTML是Hyper Text Markup Language的缩写。意思是超文本标记语言。它的作用是搭建网页结构&…

Python与c,JAVA相比,最大的问题在哪?

Python、C和Java是三种非常流行的编程语言&#xff0c;它们各自有独特的优势和劣势。Python与C和Java相比&#xff0c;可能面临以下一些挑战或问题&#xff1a; 1. 执行速度&#xff1a; Python是一种解释型语言&#xff0c;通常比编译型语言C和Java运行得慢。C语言代码通常直…

WebRTC简介

WebRTC简介 WebRTC&#xff08;Web Real-Time Communication&#xff09;是一项开源的实时通信技术&#xff0c;它允许网页浏览器进行实时语音、视频和数据共享通信&#xff0c;而无需安装额外的插件或应用程序。WebRTC的出现极大地简化了实时通信的开发和部署过程&#xff0c…

力扣 77题 组合 记录

题目描述 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。你可以按 任何顺序 返回答案。示例 1&#xff1a; 输入&#xff1a;n 4, k 2 输出&#xff1a; [[2,4],[3,4],[2,3],[1,2],[1,3],[1,4], ]示例 2&#xff1a; 输入&#xff1a;n 1, k…

混合密度网络Mixture Density Networks(MDN)

目录 简介1 介绍2 实现3 几个MDN的应用&#xff1a;参考 简介 平方和或交叉熵误差函数的最小化导致网络输出近似目标数据的条件平均值&#xff0c;以输入向量为条件。对于分类问题&#xff0c;只要选择合适的目标编码方案&#xff0c;这些平均值表示类隶属度的后验概率&#x…