首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
SAAS
ToB门户
了解全球最新的ToB事件
论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
微博
Follow
记录
Doing
博客
Blog
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
排行榜
Ranklist
相册
Album
应用中心
qidao123.com ToB IT社区-企服评测·应用市场
»
论坛
›
软件与程序人生
›
DevOps与敏捷开发
›
力扣算法Hot100——75. 颜色分类
返回列表
发新帖
力扣算法Hot100——75. 颜色分类
[复制链接]
发表于 2025-10-12 08:04:28
|
显示全部楼层
|
阅读模式
解法1: 固然可以冒泡排序,时间复杂度O(n2n^2n2)
解法2:单指针
循环两次,第一次循环将全部的 0 互换到前面;
第二次循环将全部的 1 互换到 0 的背面
class Solution {
public void sortColorsBySinglePointer(int[] nums) {
int zeroCnt = 0, p = 0;
for (int i = 0; i < nums.length ; i++) {
if (nums[i] == 0) {
p = nums[zeroCnt];
nums[zeroCnt] = 0;
nums[i] = p;
zeroCnt++;
}
}
// 继续沿着zeroCnt的位置放 1
for (int i = 0; i < nums.length ; i++) {
if (nums[i] == 1) {
p = nums[zeroCnt];
nums[zeroCnt] = 1;
nums[i] = p;
zeroCnt++;
}
}
}
}
复制
代码
解法3:双指针
利用一次循环,过程中利用两个指针,将全部的 0 放前面,全部的 2 放背面
大概将全部的 0 放前面,全部的 1 放 0 背面
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有账号?
立即注册
×
回复
使用道具
举报
返回列表
前进之路
+ 我要发帖
登录后关闭弹窗
登录参与点评抽奖 加入IT实名职场社区
去登录
微信订阅号
微信服务号
微信客服(加群)
H5
小程序
快速回复
返回顶部
返回列表