热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

数字能排序字符串不能排序_算法题——[leetcode1585]判断字符串s能否通过排序操作变为t...

Hard级别的新题:给定数字串s和t,它们只由0到9这10个数字组成。问你可以不断选择s的任意子串,对其进行排序,问最后能不

Hard级别的新题:给定数字串s和t,它们只由'0'到'9'这10个数字组成。问你可以不断选择s的任意子串,对其进行排序,问最后能不能把它变为t?

数据范围: s和t只由数字组成,并且长度相同,长度不超过100000。

例如s = "84532" t = "34852", 返回true。

我们可以选择先对s的前4个字符排序,变为"34582"

再对s的下标为2和3的两个字符排序,变为"34852"得到t。

分析:有点意思的题。问题的关键是,对任意子串排序和对任意长度为2的子串排序——对相邻两个字符排序,没有任何区别。看起来对相邻两个字符排序的操作要弱于对任意子串排序,但其实它们是等效的。因为如果我们要对某个子串排序,我们可以选择这个子串里的最小的,通过对相邻两个字符排序的操作,将其换到子串的开头,再找到次小的,把它换到第2个位置——就像冒泡排序一样。因此,我们可以简单地考虑是否能通过对相邻两个字符排序,把s变为t。

方法1 由小到大处理字符c。我们看字符c在s和t出现的位置。这里必须满足s和t中该字符出现的次数一样多,并且t中该字符出现的每个位置一定要不大于s中该字符出现的每个位置——这样该字符可以不断左移动到指定位置,然后我们再把所有的c从s和t中删掉,继续统计下一个字符。

这里多说两句,真正的操作过程是反过来的,先处理9,这时0-8都删光了,所以只要个数相等,就一定没问题。然后处理8,这时实际上字符串只有8和9,然后按照我们的判断方法,只要t中每个8的位置比s中8的位置更靠前,则就可以。因为8在只有8和9的世界里,8可以自由地往前换……如此类推。

可是在实现时,我们c是从0-9循环的,每次判断位置时,忽略掉小于它的字符即可,而没有必要真正地删除。

代码:

class Solution {public: bool isTransformable(string s, string t) { for (char c &#61; &#39;0&#39;; c <&#61; &#39;9&#39;; &#43;&#43;c) { vector v; for (int i &#61; 0, p &#61; 0; i &#61; c) { &#43;&#43;p; } } int num &#61; 0; for (int i &#61; 0, p &#61; 0; i &#61; v.size() || v[num] &#61; c) { &#43;&#43;p; } } if (num !&#61; v.size()) { return false;            }             } return true; }};

方法2 按照t中的顺序处理。思路类似。我们统计s中每个字符出现的位置。然后对t中的每个字符&#xff0c;我们知道该字符是该数字的第几次出现。设这个字符是x, 若其可以移动到指定位置(无论前移还是后移)&#xff0c;只要保证s中比x小的还没处理的字符不在x之前(左)出现就好。因为如果这样一个字符y存在&#xff0c;y在s中比 x更靠前(左)&#xff0c;而在t中比x更靠后(右)&#xff0c;而y

代码&#xff1a;

class Solution {public: bool isTransformable(string s, string t) { vector> p(10); vector ind(10); for (int i &#61; 0; i &#61; p[c].size()) { return false; } for (int j &#61; 0; j

1a64d641dd62807795425d8f2377bfdf.png




推荐阅读
  • 电话号码的字母组合解题思路和代码示例
    本文介绍了力扣题目《电话号码的字母组合》的解题思路和代码示例。通过使用哈希表和递归求解的方法,可以将给定的电话号码转换为对应的字母组合。详细的解题思路和代码示例可以帮助读者更好地理解和实现该题目。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 李逍遥寻找仙药的迷阵之旅
    本文讲述了少年李逍遥为了救治婶婶的病情,前往仙灵岛寻找仙药的故事。他需要穿越一个由M×N个方格组成的迷阵,有些方格内有怪物,有些方格是安全的。李逍遥需要避开有怪物的方格,并经过最少的方格,找到仙药。在寻找的过程中,他还会遇到神秘人物。本文提供了一个迷阵样例及李逍遥找到仙药的路线。 ... [详细]
  • STL迭代器的种类及其功能介绍
    本文介绍了标准模板库(STL)定义的五种迭代器的种类和功能。通过图表展示了这几种迭代器之间的关系,并详细描述了各个迭代器的功能和使用方法。其中,输入迭代器用于从容器中读取元素,输出迭代器用于向容器中写入元素,正向迭代器是输入迭代器和输出迭代器的组合。本文的目的是帮助读者更好地理解STL迭代器的使用方法和特点。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • IhaveconfiguredanactionforaremotenotificationwhenitarrivestomyiOsapp.Iwanttwodiff ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • WebSocket与Socket.io的理解
    WebSocketprotocol是HTML5一种新的协议。它的最大特点就是,服务器可以主动向客户端推送信息,客户端也可以主动向服务器发送信息,是真正的双向平等对话,属于服务器推送 ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • 本文介绍了Codeforces Round #321 (Div. 2)比赛中的问题Kefa and Dishes,通过状压和spfa算法解决了这个问题。给定一个有向图,求在不超过m步的情况下,能获得的最大权值和。点不能重复走。文章详细介绍了问题的题意、解题思路和代码实现。 ... [详细]
author-avatar
mobiledu2502860643
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有