242. 有效的字母异位词 golang

242. 有效的字母异位词

两个单词如果包含相同的字母,次序不同,则称为字母易位词(anagram)

思路

  1. 字符转换成byte
  2. byte排序
  3. byte挨个对比
// 两个单词如果包含相同的字母,次序不同
func quickSort(arr []byte, left int, right int) {if left > right {return}i := leftj := rightget := arr[right];for i < j {for i < j && arr[i] <= get{i++}arr[j] = arr[i]for i < j && arr[j] >= get {j--}arr[i] = arr[j]}arr[i] = getquickSort(arr,left,i- 1)quickSort(arr,i+1,right)
}func isAnagram(s string, t string) bool {if len(t) > len(s) || len(t) < len(s){return false}sq1 := []byte(s)sq2 := []byte(t)quickSort(sq1, 0, len(sq1)-1)quickSort(sq2, 0, len(sq2)-1)for i:=0; i<len(s); i++ {if sq1[i] != sq2[i]{return false}}return true
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/382234.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

leetcode验证冒泡排序效率

结论&#xff1a;快排比冒泡慢 bubbleSort leetcode_bubbleSort // 两个单词如果包含相同的字母&#xff0c;次序不同 func bubbleAsort(values []byte) {for i : 0; i < len(values)-1; i {for j : i1; j < len(values); j {if values[i]>values[j]{values[i],va…

QString转化为const char *出现乱码问题

对于Qt项目开发中&#xff0c;常常会遇到QString和const char*的转化问题&#xff0c;Qt也提供了响应的API接口&#xff0c;可以把QString转化为QByteArray&#xff0c;然后再转化为const char *,具体代码如下&#xff1a; QString string("helloWorld"); const cha…

go有没有引用类型

没有引用类型 go没有引用类型在函数内部修改变量&#xff1f; 指针类型 测试代码如下 package mainimport "fmt"func add(a int) {fmt.Println("a int")fmt.Printf("%d\n", &a)a 1 }func add2(a *int) {fmt.Println("a *int"…

Qt中的QByteArray和自定义结构体之间的相互转换

在Qt项目开发中&#xff0c;经常会碰到自定义结构体和字符数组之间的转换问题&#xff0c;不妨假设结构体名字为custom_struct, 字符数组名字为array_data 1. QByteArray转换为自定义结构体 custom_struct *struct_data reinterpret_cast<custom_struct *>(array_data…

20. 有效的括号 golang(2)

ASCII码来处理 第一种方法使用了栈的包&#xff0c;这种方式使用了ASCII码处理&#xff0c;但是&#xff0c;做题的时候还是需要查 //ASCII码 {123 }125 (40 )41 [91 ]93 func isValid(s string) bool {size : len(s)stack : make([]byte, size)top : 0 for i:0; i<size; i …

Qt控件大小自适应电脑分辨率问题

在最近的Qt工具开发工程中&#xff0c;发现一个问题&#xff1a;在自己电脑(分辨率是1366*768)上开发出来的工具&#xff0c;发布给同事(分辨率1920*1280)使用的过程中却出现了空间字体&#xff0c;边框等变形的问题&#xff0c;最后发现原因是因为在样式设计中&#xff0c;混合…

27. 移除元素 golang

空间复杂度O(1) 题目中不需要保持数组按照原来的顺序。 返回值是删除完key的剩余元素个数。所以我们使用前后指针&#xff0c;f指针指到key的位置&#xff0c;l指最后非key的位置。交换元素。 func removeElement(nums []int, val int) int {i, j : 0, len(nums) - 1for {for …

Qt 编译错误 LINK2001:无法解析的外部符号 public: virtual struct QMetaObject const thiscall Widget::metaObject

对于Qt来说&#xff0c;signal和slots是Qt的核心&#xff0c;而对于信号来说&#xff0c;只有继承了QObject的类&#xff0c;并且在类中添加Q_OBJECT宏&#xff0c;信号才能有效地和槽建立连接。可是在Qt开发的前期&#xff0c;可能预测不到需要在类中添加信号&#xff08;也就…

122. 买卖股票的最佳时机 II golang

Me 输入: [7,1,5,3,6,4] 输出: 7 输入: [1,2,3,4,5] 输出: 4 输入: [7,6,4,3,1] 输出: 0 得出的结论就是当有了股票只要明天跌就今天卖。只要明天涨今天就买&#xff08;只限于做题&#xff1f;&#xff1f;&#xff1f;&#xff09; func maxProfit(prices []int) int {res…

Qt中QLabel的背景图片设置问题

在Qt开发的过程中&#xff0c;经常会遇到设置Label的背景图片问题&#xff0c;通常可以有一下两种方法设置&#xff1a; 方法1&#xff1a;通过setScaleContents来设置(有时候会出现svg图片无法自适应label大小的问题) QPixmap pixmap("***.svg"); label->setFix…

860. 柠檬水找零 golang

Me 不可以让后面有零钱的人先来买。所以这个题不能排序 题目的点在于20块钱找零15。15可以是5 5 5 15 或10 5 15这两种组合 func lemonadeChange(bills []int) bool {var sum5, sum10 int//sort.Ints(bills)for i:0; i<len(bills); i {switch bills[i] {case 5:sum5cas…

Qt中槽函数触发两次的两种场景分析

在Qt开发中&#xff0c;有两种情况能够触发槽函数被触发两次&#xff0c;第一种情况是必现的&#xff0c;属于错误的写法&#xff0c;是指信号和槽关联两次&#xff1b;第二种情况是偶然出现的&#xff0c;是指对信号没有正确理解导致的。 1.信号与槽关联两次 通常这种情况下发…

55. 跳跃游戏 golang

55. 跳跃游戏 给定一个非负整数数组&#xff0c;你最初位于数组的第一个位置。 数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个位置。 示例 1: 输入: [2,3,1,1,4] 输出: true 解释: 我们可以先跳 1 步&#xff0c;从位置 0 到达 位置 1,…

134. 加油站 golang

Me 1.油量之和大于油费之和(不够用的汽油debts大于多出来的汽油remains) 2.车程转成一个圈。如果车无法开到i1那么起点就是i1(gas[i] < cost[i] -->i1) func canCompleteCircuit(gas []int, cost []int) int {remains, debts, start : 0, 0 ,0for i,g : range gas {remai…

从mice到missForest:常用数据插值方法优缺点

一、引言 数据插值方法在数据处理和分析中扮演着至关重要的角色。它们可以帮助我们处理缺失数据&#xff0c;使得数据分析更加准确和可靠。数据插值方法被广泛应用于金融、医疗、社会科学等领域&#xff0c;以及工程和环境监测等实际应用中。 在本文中&#xff0c;我们将探讨三…

605. 种花问题 golang 切片越界问题和逻辑操作符的思考

关于切片越界的问题&#xff0c;这个解法给了参考 测试用例 0,0,1,0,1 从这个测试用例中&#xff0c;我们可以看到一次性就写出下面的if语句是有一定难度的 第一个元素就是0&#xff0c;所以第一个条件成立后&#xff0c;进行i-1判断就越界了。但是这个0是可以改为1的&#…

376. 摆动序列 golang

376. 摆动序列 求取所有的差值保存起来。然后再判断一正一负的规律是否成立 var flag int func wiggleMaxLength(nums []int) int {if len(nums) < 1 {return 0}if len(nums) 1 {return 1}var res intresult : make([]int,len(nums))m : 0for i:0; i<len(nums)-1; i {if…

392. 判断子序列 golang 关于布尔类型返回值判断的思考

Me 1.取每一个字符串的字符进行比较。 2.相等就i&#xff0c;j&#xff0c;不相等就j 3.如果s空了&#xff0c;那么就是true。如果t字符串空了那么。。。有很多种情况。所以这个解法不好。 但是如果把返回条件设置成下面这个答案就很好 解法 这个的巧妙之处在于返回值判断是否…

402. 移掉K位数字 golang

测试用例 示例 2 : 输入: num “10200”, k 1 输出: “200” 解释: 移掉首位的 1 剩下的数字为 200. 注意输出不能有任何前导零。 示例 3 : 输入: num “10”, k 2 输出: “0” 解释: 从原数字移除所有的数字&#xff0c;剩余为空就是0。 Me 如果下一个元素比当前栈元素…

121. 买卖股票的最佳时机 golang

Me 记录最大值最小值 在更新最小值的时候&#xff0c;我们忽略前面的最大值&#xff0c;并重新以当前最小值为起点&#xff01;&#xff08;但是可能目前的收益最多&#xff0c;所以创建变量保存收入&#xff09;在产生最大值的时候&#xff0c;我们需要计算当前利润是否大于历…