Re: [闲聊] 每日leetcode

楼主: JIWP (JIWP)   2024-12-23 20:32:25
2471. Minimum Number of Operations to Sort a Binary Tree by Level
思路
就bfs并且用一个array记录每一个level所有node的值
接着将array的值复制到另外一个矩阵copy_arr
再把copy_arr排列好
最后去比对array跟copy_arr的每个值
如果array[i]跟copy_arr[i]同
就去找array[i]在copy_arr的哪个index并且换过去
每换一次ans就+1
直到array[i]跟copy_arr[i]相等再将i+1去比较下一个值
这样就可以得到答案了
golang code :
/**
* Definition for a binary tree node.
* type TreeNode struct {
* Val int
* Left *TreeNode
* Right *TreeNode
* }
*/
func minimumOperations(root *TreeNode) int {
queue := []*TreeNode{root}
ans := 0
for len(queue) > 0 {
cnt := len(queue)
arr := []int{}
for cnt > 0 {
node := queue[0]
queue = queue[1:]
if node.Left != nil {
arr = append(arr, node.Left.Val)
queue = append(queue, node.Left)
}
if node.Right != nil {
arr = append(arr, node.Right.Val)
queue = append(queue, node.Right)
}
cnt

Links booklink

Contact Us: admin [ a t ] ucptt.com