首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Leetcode No.1202 交换字符串元素

一、题目描述 给你一个字符串 s,以及该字符串一些「索引对」数组 pairs,其中 pairs[i] = [a, b] 表示字符串两个索引(编号从 0 开始)。...你可以 任意多次交换 在 pairs 任意一对索引处字符。 返回在经过若干次交换后,s 可以变成按字典序最小字符串。...二、解题思路 把pair索引对看成无向图路径,那么pairs[i] = [a, b]表示存在路径 使用图遍历算法,计算出图所有连通分量,以及在同一个连通分量所有字符索引 同一个连通分量字符可以任意交换位置...,如[0, 3], [0, 2],则索引0, 2, 3字符可以任意相互交换 对同一个连通分量字符进行排序,再按相应索引放回到原字符串,即可得到按字典序升序最小字符串 可以使用DFS,或BFS...,如[0, 3], [0, 2],则索引0, 2, 3字符可以任意相互交换 # 对同一个连通分量字符进行排序,再按相应索引放回到原字符串,即可得到按字典序升序最小字符串

60230
您找到你想要的搜索结果了吗?
是的
没有找到

并查集经典题解——交换字符串元素

在LeetCode上标签为“并查集”题目不少,大部分题目在使用并查集后,解法一目了然,十分清晰,比如这篇文章要分析一个题目——交换字符串元素。...其中: pairs[0]=[0,3]——s第0和第3个位置字符可以交换位置(任意多次)。即“dcab”可以变成“bcad”,因为b比d小(排在字典序前面)。...pairs[1]=[1,2]——s第1和第2个位置字符可以交换位置(任意多次)。即“dcab”可以变成“dacb”。结合着pairs[0],即可变为"bacd",因为a比c小。...pairs[2]=[0,2]——s第0和第2个位置字符可以交换位置(任意多次)。注意结合pairs[0],第0个字符和第3个字符可以互换位置,那么现在第0、2、3个字符都可以互换位置。...根据上面的分析,这道题可以分成两个步骤: 联合:查看pairs里哪些组合可以形成一个集合,比如[0,3]和[2,3]可以构成一个集合[0,2,3]; 排序:将集合交换位置对应字符按照字典序排序

42810

java数字以及如何判断字符串是不是数字

前言 数字是计算机科学根本,那么java数字是怎样来表示呢?规则又是怎样呢?今天我们来探讨一下这个话题。数字在某些领域经常用字符串来进行表示和传递。...那么我们可以从判断java中一个字符串是否是数字来获取一些有用信息。 空字符和null 首先我们可以很清晰知道空字符`""`和`null` 肯定不是数字。其实我们写其他逻辑一样。...// A-F 代表十六进制 10-15 false System.out.println("0xAF 是不是数字:"+isNumeric("0xAF")); // double...如果字符串不符合对应数字类型规则将抛出`NumberFormatException` 异常。...如果你不考虑这种情况应该是`isCreatable` 基本能满足需要。 总结 今天通过对字符串是否是java数字类型进行一些验证,让我们对java数字又进行了回顾。

4.5K30

JavaScript字符串数字陷阱(示例)

有很多种方式可以将字符串转为数字。我能想到方式就至少有5种!...(-0xFF) // returns -255 parseFloat("-0xFF") // returns 0 (注, 一个负 16 进制数字符串是比较特殊例子,当你在应用解析它时候,可能会导致意想不到错误...您仅可以使用它将字符串转换为整型,而不能转为浮点型数字。它比较好一面是,当碰到非数字字符时候,它会返回 0。...不过一元操作并不是性能最好一种方式 ——— 即使 -0 操作性能不错。 字符串数字最好方式? 负 16 进制数是唯一在字符串中断开数字。...其它数字应首先解析成字符串,然后通过一元操作或者带有基数 parseInt 来解析成数字。parseFloat 具有性能上优势,但是它会在相较于返回 NaN 更为合适情况下返回一些数字

1.4K10

python:过滤字符串字母数字特殊

今天遇到字符串处理问题,记录一下方便使用 1 str1 = input('请输入一个字符:') 2 #初始化字符、数字、空格、特殊字符计数 3 lowercase = 0 4 uppercase...if strs.islower(): 11 lowercase += 1 12 #如果在字符串中有数字,那么数字数量+1 13 elif strs.isdigit():...: 22 other += 1 23 print ("该字符串小写字母有:%d" %lowercase) 24 print ("该字符串大写写字母有:%d" %uppercase...) 25 print ("该字符串数字有:%d" %number) 26 print ("该字符串空格有:%d" %space) 27 print ("该字符串特殊字符有:%d" %other...) View Code 字符串.isalnum()  所有字符都是数字或者字母,为真返回 Ture,否则返回 False。

3.3K10

交换字符串元素(并查集)

题目 给你一个字符串 s,以及该字符串一些「索引对」数组 pairs,其中 pairs[i] = [a, b] 表示字符串两个索引(编号从 0 开始)。...你可以 任意多次交换 在 pairs 任意一对索引处字符。 返回在经过若干次交换后,s 可以变成按字典序最小字符串。...示例 1: 输入:s = "dcab", pairs = [[0,3],[1,2]] 输出:"bacd" 解释: 交换 s[0] 和 s[3], s = "bcad" 交换 s[1] 和 s[2],..."abc" 解释: 交换 s[0] 和 s[1], s = "bca" 交换 s[1] 和 s[2], s = "bac" 交换 s[0] 和 s[1], s = "abc" 提示: 1 <= s.length...解题 参考:数据结构–并查集(Disjoint-Set) 把同一个集合排序,然后放回去 class dsu { public: vector f; dsu(int n) { f.resize

69420

PHP字符串数字比较

PHP字符串数字比较 在日常开发过程,==运算符是我们每天都会接触到。这个运算符其实埋了非常多坑,今天我们就来看下字符串数字用==比较需要注意问题。...,也就是说,这些字符串在对比时候进行了类型转换,都被强转成了int型。...('aa' == "aa\n"), PHP_EOL; 这时候结果就符合我们预期了,他们本身就是字符串比对,不会进行任何类型转换: 1"aa" == " aa" is 2"aa" == "\naa..." is 3"aa" == "aa" is 1 4"aa" == "aa " is 5"aa" == "aa\n" is 综上实验结果得知,当字符串内容都是int数据时,字符串==比较会忽略在字符串前面出现空格或者制表符号将它们强制转换成...而只要字符串包含文本或者特殊符号在数字后面,就会以文本方式进行比较,如纯文本或者混合文本("11aa"、"11\n"、"aa11 ")。

2K30

js字符串转换为数字

js 字符串转化成数字三种方法主要有 转换函数、强制类型转换、利用js变量弱类型转换。 1. 转换函数:   js提供了parseInt()和parseFloat()两个转换函数。...ECMAScript可用3种强制类型转换如下:   Boolean(value)——把给定值转换成Boolean型;   Number(value)——把给定值转换成数字(可以是整数或浮点数);...用这三个函数之一转换值,将创建一个新值,存放由原始值直接转换成值。这会造成意想不到后果。 当要转换值是至少有一个字符字符串、非0数字或对象时,Boolean()函数将返回true。...如果该值是空字符串数字0、undefined或null,它将返回false。 可以用下面的代码段测试Boolean型强制类型转换。   ...,实现了字符串数字类型转换,不过这个方法还是不推荐

11.4K41

Excel公式:删除字符串所有数字

标签:Excel公式,SUBSTITUTE函数 有时候,可能是由于输入原因,也可能是由于从网上直接下载数据,数据字符串夹杂着一些数字,而我们又不想要这些数字,因此,需要从字符串删除这些数字。...例如,字符串“My2017Excel2022”删除其中数字后,成为“MyExcel”。 使用什么公式能够达到我们目的呢?...首先很自然想到是SUBSTITUE函数,可以用新字符来替换字符串原字符。...SUBSTITUTE(B2,1,""),2,""),3,""),4,""),5,""),6,""),7,""),8,""),9,""),0,"") 公式有点长,但基本原理很简单,就是使用SUBSTITUTE函数依次替换字符串数字...由于有十个数字,因此使用了SUBSTITUTE函数10次。 幸好只有10个数字,只需替换操作10次,如果更多的话,公式岂不很长。不知道有没有更简单通用公式,期待朋友们一起探讨。

2.8K30

字符串数字之和高级方法

标签:Excel公式与函数,FILTERXML函数 如下图1所示,在单元格B2包含由逗号分隔数字组成字符串。...图1 现在,需要求这些数字之和,即: 15+6+2022+9+606+89+2=2749 如何编写公式来获得结果?...使用一定数量空格代替字符串逗号来分隔数字,然后提取出各个数字,得到由这些数字字符串组成数组,双减号(--)使数组数字字符串转换成数字,传递给SUM函数求和,从而得到结果,如下图2所示。...前面我们讲解过FILTERXML函数,参考: FILTERXML函数妙用 FILTERXML函数又来了,轻松反转由词语组成字符串 使用FILTERXML函数公式更简洁: =SUM(FILTERXML...单击功能区“公式”选项卡“定义名称”,在新建名称对话框,输入名称: GetSum 在引用位置输入公式: =EVALUATE(SUBSTITUTE(B2,",","+")) 定义好名称如下图4所示

1.2K50

python提取字符串数字「建议收藏」

一、isdigit()函数 isdigit()函数是检测输入字符串是否只由数字组成。如果字符串只包含数字则返回 True 否则返回 False。...该接收两个参数,第一个为函数,第二个为序列,序列每个元素作为参数传递给函数进行判断,然后返回 True 或 False,最后将返回 True 元素放到新列表。...语法: filter(function, iterable) 1、过滤出列表所有奇数: def is_odd(n): return n % 2 == 1 tmplist = filter...(is_odd, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]) newlist = list(tmplist) print(newlist) 2、过滤出列表所有偶数: l = [...filter(_not_divisible(n), ftr ) #3 for n in primes(): if n < 100: print('now:',n) else: break 三、提取一段字符串数字

3.7K20
领券