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

代码随想录算法训练营第五天 |242.有效的字母异位词、349. 两个数组的交集、第202题. 快乐数、1. 两数之和

242.有效的字母异位词

 思路:想到的是分别遍历两个数组,然后用map统计值,一个数组遍历的时候对值++,一个--,如果value没有能消除完,那就不一样。
优化:其实一次遍历就可以做完。
func isAnagram(s string, t string) bool {hash := map[byte]int{}len_s := len(s)len_t := len(t)for i := 0 ; i < len_s ; i++{hash[s[i]]++}for i := 0 ; i < len_t ; i++{hash[t[i]]--}for i,_ := range hash{if hash[i]!= 0{return false}}return true
}

  

  

349. 两个数组的交集

思路:一开始也想用242的方法,但是不能仅仅从偶数基数来判断,然后想的办法是先把一个数组遍历,存入map中,第二个数组遍历看map里面有不有这个数,然后再穿插一个去重数组。  

func intersection(nums1 []int, nums2 []int) []int {res := make([]int,0)hash1 := map[int]int{}inout := map[int]int{}for _,i2 := range nums1{hash1[i2]++}for _,i2 := range nums2{if hash1[i2] != 0 && inout[i2] == 0{res = append(res,i2)inout[i2]++}}return res
}

  

202.快乐数

用-1 和1的返回值来代表输出值,一开始想错了以为个位数就不用判断了,直接看是不是1,其实真正的结束判断是用看是否一个结果出现了两次,如果出现了两次那就是错的。

func isHappy(n int) bool {sumtotal := map[int]int{}res := judgehappy(n,sumtotal)for res != -1 && res != 1{res = judgehappy(res,sumtotal)}if res == -1{return false}else{return true}
}
func judgehappy(n int,sumtotal map[int]int) int{res := make([]int,0)tmp := nfor tmp != 0{res = append(res,tmp % 10)tmp /= 10}sum := 0for _,i2 := range res{sum += i2 * i2}sumtotal[sum]++for _,i2 := range sumtotal{if i2 > 1{return -1}}return sum
}

  

1.两数之和

思路:暴力思路不多讲,优化的话就是遍历一次数组,边遍历边把数组出现的值和坐标放到哈希表,然后一次一次向哈希表查这个值是否存在,如果有输出没有就往前走

func twoSum(nums []int, target int) []int {m := make(map[int]int)for i, num := range nums {complement := target - numif index, found := m[complement]; found {return []int{index, i}}m[num] = i}return nil  // 返回空数组 nil 代替空切片
}

  

 

 

 

http://www.hskmm.com/?act=detail&tid=13761

相关文章:

  • Photoshop 2025 v26.0(PS2025)下载安装教程(含一键安装包下载)
  • 网络加速原理
  • 循环依赖问题
  • 无意中在应用层瞥见了一个微内核的操作系统调度器
  • 数据结构思维题选做(长期更新)
  • 政治笔记/错题
  • 9.22模拟赛总结
  • 莫队 n的序列,多次查询一段区间内的数字的个数
  • 【mysql】mysql客户端中文显示乱码
  • 揭秘“牛牛透视”
  • k8s系列--控制器yml(15)
  • 学生管理系统案例初步分析报告
  • 【mysql】mysql5.6 版本修改用户的登录
  • AT_abc200_e [ABC200E] Patisserie ABC 2 题解
  • 日总结 5
  • Linux驱动开发(1)概念、环境与代码框架 - 实践
  • Diffutoon下载介绍:真人视频转动漫工具,轻松获得上千点赞
  • 9月22号
  • 0.5*8 边形 != 式
  • 题解:AT_agc052_c [AGC052C] Nondivisible Prefix Sums
  • 寻路算法
  • 2025年9月22日 - 20243867孙堃2405
  • day 1
  • [Paper Reading] METAGPT: META PROGRAMMING FOR A MULTI-AGENT COLLABORATIVE FRAMEWORK
  • 二进制 - 20243867孙堃2405
  • 学习问题日记-1
  • 记一次生产环境内存溢出记录
  • 四舍六入五成双
  • 借助 Apache Phoenix,使用标准 SQL 和 JDBC 接口来操作 HBase
  • 学生信息管理系统