开心灿烂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

}

相关推荐
颜酱9 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
m0_736919109 小时前
C++代码风格检查工具
开发语言·c++·算法
yugi9878389 小时前
基于MATLAB强化学习的单智能体与多智能体路径规划算法
算法·matlab
DuHz10 小时前
超宽带脉冲无线电(Ultra Wideband Impulse Radio, UWB)简介
论文阅读·算法·汽车·信息与通信·信号处理
Polaris北极星少女10 小时前
TRSV优化2
算法
代码游侠11 小时前
C语言核心概念复习——网络协议与TCP/IP
linux·运维·服务器·网络·算法
2301_7634724611 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
abluckyboy12 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法
园小异12 小时前
2026年技术面试完全指南:从算法到系统设计的实战突破
算法·面试·职场和发展
m0_7066532312 小时前
分布式系统安全通信
开发语言·c++·算法