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

青岛模板建站多少钱企业外部网站建设

青岛模板建站多少钱,企业外部网站建设,北京网站建设外包公司,上海十大企业本文属于「征服LeetCode」系列文章之一,这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁,本系列将至少持续到刷完所有无锁题之日为止;由于LeetCode还在不断地创建新题,本系列的终止日期可能是永远。在这一系列刷题文章…

本文属于「征服LeetCode」系列文章之一,这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁,本系列将至少持续到刷完所有无锁题之日为止;由于LeetCode还在不断地创建新题,本系列的终止日期可能是永远。在这一系列刷题文章中,我不仅会讲解多种解题思路及其优化,还会用多种编程语言实现题解,涉及到通用解法时更将归纳总结出相应的算法模板。

为了方便在PC上运行调试、分享代码文件,我还建立了相关的仓库:https://github.com/memcpy0/LeetCode-Conquest。在这一仓库中,你不仅可以看到LeetCode原题链接、题解代码、题解文章链接、同类题目归纳、通用解法总结等,还可以看到原题出现频率和相关企业等重要信息。如果有其他优选题解,还可以一同分享给他人。

由于本系列文章的内容随时可能发生更新变动,欢迎关注和收藏征服LeetCode系列文章目录一文以作备忘。

给你一个仅由字符 '0' 和 '1' 组成的字符串 s 。一步操作中,你可以将任一 '0' 变成 '1' ,或者将 '1' 变成 '0' 。

交替字符串 定义为:如果字符串中不存在相邻两个字符相等的情况,那么该字符串就是交替字符串。例如,字符串 "010" 是交替字符串,而字符串 "0100" 不是。

返回使 s 变成 交替字符串 所需的 最少 操作数。

示例 1:

输入:s = "0100"
输出:1
解释:如果将最后一个字符变为 '1' ,s 就变成 "0101" ,即符合交替字符串定义。

示例 2:

输入:s = "10"
输出:0
解释:s 已经是交替字符串。

示例 3:

输入:s = "1111"
输出:2
解释:需要 2 步操作得到 "0101""1010"

提示:

  • 1 <= s.length <= 10^4
  • s[i] 是 '0' 或 '1'

解法 模拟

根据题意,经过多次操作, s s s 可能会变成两种不同的交替二进制字符串,即:

  • 开头为 0 0 0 ,后续交替的字符串;
  • 开头为 1 1 1 ,后续交替的字符串。

注意到,变成这两种不同的交替二进制字符串所需要的最少操作数加起来等于 s s s 的长度,我们只需要计算出变为其中一种字符串的最少操作数,就可以推出另一个最少操作数,然后取最小值即可。

// cpp
class Solution {
public:int minOperations(string s) {int cnt = 0;for (int i = 0; i < s.size(); ++i) {char c = s[i];if (c != ('0' + i % 2)) ++cnt;}return min(cnt, (int)s.size() - cnt);}
};// java
class Solution {public int minOperations(String s) {int cnt = 0;for (int i = 0; i < s.length(); ++i) {char c = s.charAt(i);if (c != (char)('0' + i % 2)) ++cnt;}return Math.min(cnt, s.length() - cnt);}
}// python
class Solution:def minOperations(self, s: str) -> int:cnt = sum(int(c) != i % 2 for i, c in enumerate(s)) # 010101...return min(cnt, len(s) - cnt)// go
func minOperations(s string) int {cnt := 0for i, c := range s {if i % 2 != int(c - '0') {cnt++}}return min(cnt, len(s) - cnt)
}
func min(a, b int) int {if a > b {return b}return a
}

复杂度分析:

  • 时间复杂度: O ( n ) O(n) O(n) ,其中 n n n 为输入 s s s 的长度,仅需遍历一遍字符串。
  • 空间复杂度: O ( 1 ) O(1) O(1) ,只需要常数额外空间。
http://www.15wanjia.com/news/159962.html

相关文章:

  • 深圳服饰网站建设贵港市网站建设
  • 淮安市建设工程初级职称申报网站wordpress memcache
  • 婚纱摄影网站开发的目的wordpress登陆后
  • 广州快速建站哪家服务专业株洲网站建设和制作
  • 寺庙网站开发做跨境都有哪些网站
  • dhl做运单的网站德州手机网站建设
  • 网站要实名认证吗免费关键词优化排名软件
  • 徐州免费网站制作制造企业erp管理系统
  • 网站建设服务哪个便宜啊做h5动画网站
  • 象山县住房和城乡建设局网站怎样把已经有的网站做推广
  • 许昌企业网站去哪开发建设网站都要什么
  • 企业外贸网站建设方案关键词歌词林俊杰
  • 网站建设移交手续建设网站需要哪些元素
  • 网站信用认证可以自己做吗文化传媒 网站设计
  • 苏州网站建设哪家好网站开发设计选题背景
  • 公司内部网站系统wordpress 文章备份
  • 哪里可以学网站开发发布网站需要多少钱
  • 建站报告2000字手机网站开发框架php
  • 建公司网站的详细步骤手机网站底部导航
  • 湛江网站建设开发中国网络营销网
  • 长春火车站停车场24小时收费标准wordpress 128m内存
  • 网站建设与维护的国家定价标准包头网站建设哪家好
  • 兰山网站建设公司网站的技术解决方案
  • 潍坊科技网站建设新博念 足球网站开发
  • 网站优化怎样做泉州网站建设效率网络
  • wap网站还有能打开的吗网站建设div ass
  • 有没有免费制作网站的wordpress 2013
  • 新开传奇网站发布网单wordpress国内不使用方法
  • 网站在线支付网络设备主要用于网站局域网建设
  • 鄂北局网站建设者风采wordpress主题 粉色