开心灿烂go开发面试题

1.给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

示例1:

输入:head = [1,2,3,4,5]

输出:[5,4,3,2,1]

package main

import "fmt"

type ListNode struct {

Val int

Next *ListNode

}

func main() {

l1 := &ListNode{Val: 1}

l2 := &ListNode{Val: 2}

l3 := &ListNode{Val: 3}

l4 := &ListNode{Val: 4}

l5 := &ListNode{Val: 5}

l1.Next = l2

l2.Next = l3

l3.Next = l4

l4.Next = l5

newlist := reverseList(l1)

for newlist != nil {

fmt.Print(newlist.Val)

if newlist.Next != nil {

fmt.Print(",")

}

newlist = newlist.Next

}

fmt.Println()

}

func reverseList(head *ListNode) *ListNode {

if head == nil || head.Next == nil {

return head

}

var prev *ListNode

cur := head

for cur != nil {

cur.Next, prev, cur = prev, cur, cur.Next

}

return prev

}

2.给你一个整数数组 nums 和一个整数 k 。你需要找到 nums 中长度为 k 的 子序列 ,且这个子序列的 和最大 。

请你返回 任意 一个长度为 k 的整数子序列。

子序列 定义为从一个数组里删除一些元素后,不改变剩下元素的顺序得到的数组。

示例1:

输入:nums = [2,1,3,3], k = 2

输出:[3,3]

示例2:

输入:nums = [-1,-2,3,4], k = 3

输出:[-1,3,4]

示例3:

输入:nums = [3,4,3,3], k = 2

输出:[3,4]

package main

import (

"fmt"

"sort"

"strconv"

"strings"

)

func main() {

//nums := []int{2, 1, 3, 3}

//k := 2

nums := []int{-1, -2, 3, 4}

k := 3

newSlice := SearchMaxSlice(nums, k)

fmt.Println(newSlice)

}

func SearchMaxSlice(nums []int, k int) []int {

n := len(nums)

temp := make([]int, n)

copy(temp, nums)

sort.Slice(temp, func(i, j int) bool {

return temp[i] > temp[j]

})

newtemp := temp[:k]

newslice := []int{}

newslicestr := fmt.Sprint(newtemp)

for _, v := range nums {

if len(newslice) == k {

break

}

if strings.Contains(newslicestr, strconv.Itoa(v)) {

newslice = append(newslice, v)

}

}

return newslice

}

3.给你一个整数数组 nums 和一个整数 k ,请你统计并返回 该数组中和为 k 的子数组的个数 。

子数组是数组中元素的连续非空序列。

示例1:

输入:nums = [1,1,1], k = 2

输出:2

示例2:

输入:nums = [1,2,3], k = 3

输出:2

func main() {

//slic := []int{1, 1, 1}

slic := []int{1, 2, 3}

k := 3

fmt.Println(calSliceCount(slic, k))

}

func calSliceCount(nums []int, k int) int {

count := 0

for i := 0; i < len(nums); i++ {

sum := 0

for j := i; j < len(nums); j++ {

sum += nums[j]

if sum == k {

count++

}

}

}

return count

}

相关推荐
Zephyrtoria1 小时前
区间合并:区间合并问题
java·开发语言·数据结构·算法
你怎么知道我是队长2 小时前
GO语言---匿名函数
开发语言·后端·golang
柏箱3 小时前
容器里有10升油,现在只有两个分别能装3升和7升油的瓶子,需要将10 升油等分成2 个5 升油。程序输出分油次数最少的详细操作过程。
算法·bfs
Hello eveybody5 小时前
C++介绍整数二分与实数二分
开发语言·数据结构·c++·算法
Mallow Flowers6 小时前
Python训练营-Day31-文件的拆分和使用
开发语言·人工智能·python·算法·机器学习
不被定义的程序猿7 小时前
Golang 在 Linux 平台上的并发控制
开发语言·后端·golang
GalaxyPokemon7 小时前
LeetCode - 704. 二分查找
数据结构·算法·leetcode
leo__5208 小时前
matlab实现非线性Granger因果检验
人工智能·算法·matlab
GG不是gg8 小时前
位运算详解之异或运算的奇妙操作
算法
ifanatic8 小时前
[每周一更]-(第147期):使用 Go 语言实现 JSON Web Token (JWT)
前端·golang·json