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

协会网站方案班级网页设计模板html代码

协会网站方案,班级网页设计模板html代码,网站设计论文题目,购买手机网站推荐【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.yayakq.cn/news/927828/

相关文章:

  • 建设网站学什么媒体网络推广价格优惠
  • 重庆建站多少钱一年wordpress 手机模板调用pc内容
  • 5118站长工具箱免费傻瓜室内装修设计软件
  • 单页网站 html5 动态网站文件夹命名seo
  • 淘宝联盟做的好的网站建搜索引擎网站
  • 南昌专业网站制作公司做公司网站需不需要注册
  • 多种东莞微信网站建设网站改版费用
  • 营销型网站平台建设帮网站网站做推广被抓会判刑吗
  • 铁岭卫生职业学院官方网站建设小程序官网入口
  • 网站几个页面wordpress.模板
  • php做的网站首页是什么文件企业的管理系统有哪些
  • 怎么填写网站icp备案如何查看网站的空间大小
  • 网站建设费是什么企业信息系统开发
  • 请求php网站数据库做优秀网站
  • 人事处网站开发文献综述网站建设淘宝详情页
  • 厦门优秀的网站设计seo的定义是什么
  • 公司做网站要多长时间审核如何用wordpress做网页
  • 未来网站开发需求多上海工商局官网
  • 给网站写文章怎么做做网站找
  • 建立网站需要什么目前做网站流行的是什么
  • 做百度网站每年的费用多少钱网架厂家
  • 济南网站制作0531soso网站上内容列表怎么做
  • 荆州企业网站建设wordpress 关闭插件更新
  • 佛山网站建设开发wordpress 归档页
  • 网站 功能需求广东网站设计公司价格
  • 如何做flash游戏下载网站做网站公司需要什么职位
  • 邢台做wap网站的公司网站 添加备案号
  • 苏州定制网站建设上海网站建设sheji021
  • 有效获客的六大渠道贴吧aso优化贴吧
  • 公司网站怎么注册手机房屋3d设计软件