笔试题算法题整理

【2022】小米秋招笔试-运维开发-卷2

【大白兔奶糖取法】(爬楼梯 动态规划)

复制代码
【大白兔奶糖取法】
问题描述: 
假设你有n个大白兔奶糖,每次最多拿走一个或者两个,你有多少种不同的方法拿完全部的大白兔奶糖?(注意求解方法的时间复杂度) 

输入描述: 
大白兔奶糖的个数n (1<=n<=50) 

输出描述: 
拿完全部的大白兔奶糖的方法数 

输入样例:
 2 

输出样例: 
2
go 复制代码
func climbStairs(n int) int {
    dp := make([]int,n+1)
    dp[0] = 1	// 拿一个
    dp[1] = 1	// 拿两个
    for i := 2; i < len(dp); i ++ {
        dp[i] = dp[i-1] + dp[i-2]
    }
    return dp[n] 

}

爬楼梯 动态规划问题

【 跳方格游戏】(Leetcode 45. 跳跃游戏 II 贪心算法)

复制代码
【 跳方格游戏】
问题描述:
小米公司在中秋节会有玩游戏领奖品的团队活动,增加部门凝聚力,其中今年中秋有一个游戏是这样的: 由游戏组织者在地上画一列竖排的方格,其中每个单独的方格上都标注着一个非负整数,==一开始你位于方格的起始位置,每一个方格的数字代 表你从该位置开始可以跳跃的最大方格数。你的目标是需要用最少的跳跃次数来达到最后一个方格。最少跳跃次数的同学可以赢得中秋小礼 品。 
其中一列的方格对应使用非负整数列表表示;起始位置为数组下标0的位置;假设你总是可以跳到数组的最后一个位置。 

输入描述: 
1
非负整数列表nums(1 <= nums.length <= 10^4, 0 <= nums[i] <= 1000),表示对应方格数字 

输出描述:
1
跳到最后一个方格的最小跳跃次数 

输入样例: 
1
[3, 2, 5, 4, 7] 

输出样例: 
1
2 
golang 复制代码
func res(nums []int) int {
	n := len(nums)
	end := 0
	maxPostion := 0
	steps := 0
	for i := 0; i < n-1; i++ {
			maxPostion = max(nums[i]+i,maxPostion)
			if i == end {
				end = max
				steps++
			}
	} 
	return steps
}
func max(a,b int) int {
	if a > b {
		return a
	}else {
		return b
	}
}
相关推荐
Wenweno0o17 小时前
0基础Go语言Eino框架智能体实战-chatModel
开发语言·后端·golang
咬_咬18 小时前
go语言学习(基本数据类型)
开发语言·学习·golang·数据类型
搜佛说20 小时前
01-第1章-概述与快速开始
物联网·golang·开源·软件工程·边缘计算·嵌入式实时数据库
LlNingyu21 小时前
什么是Go的接口(二)
golang
不会写DN21 小时前
如何设计应用层 ACK 来补充 TCP 的不足?
开发语言·网络·数据库·网络协议·tcp/ip·golang
不会写DN1 天前
如何给 Go 语言的 TCP 聊天服务加上 ACK 可靠送达机制
开发语言·tcp/ip·golang
ZHENGZJM1 天前
后端基石:Go 项目初始化与数据库模型设计
开发语言·数据库·golang
人间打气筒(Ada)1 天前
「码动四季·开源同行」go语言:微服务网关如何作为服务端统一入口点?
微服务·golang·开源·微服务网关·go实战
ん贤1 天前
Go 并发高频十问:goroutine 与线程的区别是什么?select 底层原理是什么?
开发语言·golang·并发
宁瑶琴1 天前
COBOL语言的云计算
开发语言·后端·golang