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

做网站要用什么编程语言发稿推广

做网站要用什么编程语言,发稿推广,网站建设顺序,奢华网站模板【LetMeFly】3106.满足距离约束且字典序最小的字符串:模拟(贪心) 力扣题目链接:https://leetcode.cn/problems/lexicographically-smallest-string-after-operations-with-constraint/ 给你一个字符串 s 和一个整数 k 。 定义函…

【LetMeFly】3106.满足距离约束且字典序最小的字符串:模拟(贪心)

力扣题目链接:https://leetcode.cn/problems/lexicographically-smallest-string-after-operations-with-constraint/

给你一个字符串 s 和一个整数 k

定义函数 distance(s1, s2) ,用于衡量两个长度为 n 的字符串 s1s2 之间的距离,即:

  • 字符 'a''z'循环 顺序排列,对于区间 [0, n - 1] 中的 i ,计算所有「 s1[i]s2[i] 之间 最小距离」的

例如,distance("ab", "cd") == 4 ,且 distance("a", "z") == 1

你可以对字符串 s 执行 任意次 操作。在每次操作中,可以将 s 中的一个字母 改变 任意 其他小写英文字母。

返回一个字符串,表示在执行一些操作后你可以得到的 字典序最小 的字符串 t ,且满足 distance(s, t) <= k

 

示例 1:

输入:s = "zbbz", k = 3
输出:"aaaz"
解释:在这个例子中,可以执行以下操作:
将 s[0] 改为 'a' ,s 变为 "abbz" 。
将 s[1] 改为 'a' ,s 变为 "aabz" 。
将 s[2] 改为 'a' ,s 变为 "aaaz" 。
"zbbz" 和 "aaaz" 之间的距离等于 k = 3 。
可以证明 "aaaz" 是在任意次操作后能够得到的字典序最小的字符串。
因此,答案是 "aaaz" 。

示例 2:

输入:s = "xaxcd", k = 4
输出:"aawcd"
解释:在这个例子中,可以执行以下操作:
将 s[0] 改为 'a' ,s 变为 "aaxcd" 。
将 s[2] 改为 'w' ,s 变为 "aawcd" 。
"xaxcd" 和 "aawcd" 之间的距离等于 k = 4 。
可以证明 "aawcd" 是在任意次操作后能够得到的字典序最小的字符串。
因此,答案是 "aawcd" 。

示例 3:

输入:s = "lol", k = 0
输出:"lol"
解释:在这个例子中,k = 0,更改任何字符都会使得距离大于 0 。
因此,答案是 "lol" 。

 

提示:

  • 1 <= s.length <= 100
  • 0 <= k <= 2000
  • s 只包含小写英文字母。

解题方法:贪心

首先需要明确,越靠前的位置越重要。所以要不惜一切代价将前面字符尽可能地变小

字符变小的方式有两种:

  1. 往小的方向变。每消耗一次操作次数字符就会变小一点,直到变成了a为止。
  2. 往大的方向变。这样做的前提是剩下的操作次数足够让当前字符变大到z再变成a

因此贪心思路出来了:

在还剩有操作次数时,从前到后开始变化字符:

对于当前字符,如果剩余操作次数足够往大的方向变到a,且这样做比往小的方向变到a所需次数更少,则往大的方向变到a为止;

否则,往小的方向变,直到变到a或用完了操作次数为止。

  • 时间复杂度 O ( l e n ( s ) ) O(len(s)) O(len(s))
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++
class Solution {
public:string getSmallestString(string s, int k) {for (char &c : s) {int left = c - 'a', right = 'z' - c + 1;if (k >= right && right < left) {c = 'a';k -= right;}else {int move = min(left, k);c -= move;k -= move;}if (k == 0) {break;}}return s;}
};

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

Tisfy:https://letmefly.blog.csdn.net/article/details/140758056

http://www.15wanjia.com/news/45306.html

相关文章:

  • 济南国画网站建设宁波最好的seo外包
  • 做网站建设需要做哪些工作视频号链接怎么获取
  • 如何学做网站东莞网络优化调查公司
  • wordpress留言板隐藏关键词优化排名软件s
  • 网站内容做淘宝店铺链接影响排名吗百度信息流投放技巧
  • 创意设计网站seo关键词排名优化案例
  • 电子商务网站开发技术有哪些站长工具 忘忧草
  • 网站怎么做必须交钱吗抖音搜索引擎推广
  • 太原网站建设的公司排名可以发外链的平台
  • 青浦手机网站制作网络营销中的四种方法
  • 南宁网站开发公司长沙做网站推广
  • 做网站百度推广广东seo教程
  • 电商自建站南昌seo搜索优化
  • 网站长域名品牌策划
  • 专业做网站全包2023年7月最新疫情
  • 怎么样做网站注册量百度风云榜明星
  • 深圳画册设计网站小说榜单首页百度搜索风云榜
  • 合肥网站搭建公司哪家好站长推荐入口自动跳转
  • 长春做网站哪家好专业网站推广软件
  • 网站建设实验小结教育机构网站
  • 服务器迁移对做网站的影响网站推广seo优化
  • 网站要不要改版关键词歌词图片
  • 唐山网站建设.com怎么制作网站?
  • 网站建设包括啥逆冬seo
  • pageadmin做网站要钱吗网页模板免费html
  • 桂林森威建筑工程监理有限责任公司佛山网络排名优化
  • 邯郸做网站的谷歌seo推广服务
  • 网站建设与维护很累吗网上怎么发布广告
  • 互诺科技做网站怎么样推广优化师
  • asp做静态网站seo公司推广