leetcode 2938.区分白球与黑球

leetcode 2938.区分白球与黑球(传送门)

**思路:**把1放右边,0放左边,只要把0全部放好那么1肯定也全部放好了。考虑将靠左的0放在靠左的位置,也就是第i个0要放到下标为i-1的位置,所以直接遍历并更新已就位的0的个数即可。

时间复杂度 O(n)

cpp 复制代码
class Solution {
public:
    long long minimumSteps(string s) {
        long long n=s.length(),sum=0,ct=0;
        for(int i=0;i<n;i++){
            if(s[i]=='0'){
                sum+=i-ct;
                ct++;
            }
        }
        return sum;
    }
};
相关推荐
阿Y加油吧7 分钟前
二分查找进阶:旋转排序数组的两道经典题深度解析
数据结构·算法
想带你从多云到转晴12 分钟前
05、数据结构与算法---栈与队列
java·数据结构·算法
無限進步D12 分钟前
蓝桥杯赛后总结
算法·蓝桥杯·竞赛
QuZero16 分钟前
ReentrantLock principle
java·算法
m0_7167652318 分钟前
数据结构--顺序表的插入、删除、查找详解
c语言·开发语言·数据结构·c++·学习·算法·visual studio
Jasmine_llq19 分钟前
《B3954 [GESP202403 二级] 乘法问题》
算法·顺序输入输出算法·布尔标记算法·累乘算法·循环迭代算法·阈值判断算法·条件分支输出算法
Halo_tjn20 分钟前
Java 抽象类 知识点
java·开发语言·算法
say_fall20 分钟前
滑动窗口算法
数据结构·c++·算法
落羽的落羽21 分钟前
【算法札记】练习 | Week1
linux·服务器·c++·人工智能·python·算法·机器学习
人道领域23 分钟前
【LeetCode刷题日记】15.三数之和(梦破碎的地方)
算法·leetcode·面试