后端面试(Golang)可能会碰上的附加智力题
发布时间:2021-05-31 编辑:jiaochengji.com
教程集为您提供后端面试(Golang)可能会碰上的附加智力题等资源,欢迎您收藏本站,我们将为您提供最新的后端面试(Golang)可能会碰上的附加智力题资源
1、猴子爬山问题:
问题:一个猴子在一座n级的山脚准备爬山,猴子上山一步可跳1级或3级,试问爬到第n阶台阶,共有多少种不同的爬法?
//简单递推设计
这一问题实际上是一个整数有序可重复拆分的问题。试应用数组递推求解,设爬k级台阶的不同爬法为f(k)种。
探求f(k)的递推关系
上山最后一步到达第30级台阶,完成上山,共有f(30)种不同的爬法,到第30级之前位于哪一级呢?无非就是位于第29级(上跳1级即可到),有f(29)种;或者位于第27级(上跳3级即可到),有f(27)种;于是f(30)=f(29) f(27)
依次类推,有以下递推关系:
f(k) = f(k-1) f(k-3) (k>3)
//golang解法:
package main
import "fmt"
/*
猴子爬山
*/
func main() {
var n int
//n 大于2
fmt.Print("请输入台阶总数n:")
_, err := fmt.Scan(&n)
if err != nil {
fmt.Println("error")
return
}
ways(n)
}
func ways(n int) {
f := make([]int, n)
f[0] = 1
f[1] = 1
f[2] = 2
for i:=3; i<n; i {
f[i] = f[i-1] f[i-3]
}
//请输入台阶总数n:40
//共有2670964种不同的爬法
fmt.Printf("%d阶楼梯共有的爬法数:%d",n, f[n-1])
}
2、8个乒乓球找出其中较重的一个:
你有8个一样大小的球,其中7个的重量是一样的,另一个比较重。怎样能够用天平仅称两次将那个重一些的球找出来。
解析:
为了方便,我们将球编号为:1,2,3,4,5,6,7,8,则我们的方案如下:
step 1 :将1,2,3放在天平左侧,4,5,6放在天平右侧,进行一次称量,结果有两种:
(1). 平衡,则重球在7,8中,称量一次7和8即可获得结果;
(2). 不平衡,假设1,2,3重,则拿出1和2称量一次,假设平衡则3是重球,否则为1,2中较重的球;
4,5,6重时和1,2,3重的处理方式相同;
3、小明一家过桥问题:
题目:小明一家过一座桥,过桥时是黑夜,所以必须有灯。现在小明过桥要1秒,小明的弟弟要3秒,小明的爸爸要6秒,小明的妈妈要8秒,小明的爷爷要12秒。每次此桥最多可过两人,而过桥的速度依过桥最慢者而定,而且灯在点燃后30秒就会熄灭。问:小明一家如何过桥?
答案:1、小明和小明弟弟过桥,需要花费3秒(小明弟弟慢,花3秒),计T1 = 3秒,总用时TC=3秒;
2、小明回来,需要花费1秒,记T2=1秒,总用时TC=4秒;
3、小明爷爷和小明妈妈一起过桥,需要花费12秒,记T3=12,总用时TC=16秒;
4、小明弟弟回来,需要花费3秒,记T4=3秒,总用时TC=19秒;
5、小明和小明爸爸一起过桥,需要花费6秒,记T5=6秒,总用时TC=25秒;
6、小明回来,需要花费1秒,记T6=1秒,总用时TC=26秒;
7、小明和小明弟弟一起过桥,需要花费3秒,记T7=3秒,总用时TC=29秒;
这样,在第3步,小明爷爷和妈妈过桥后留下,第5步,小明爸爸过桥后留下,第7步,小明和小明弟弟过桥后,一家人成功在30秒内过桥。
到此这篇关于“后端面试(Golang)可能会碰上的附加智力题”的文章就介绍到这了,更多文章或继续浏览下面的相关文章,希望大家以后多多支持JQ教程网!
您可能感兴趣的文章:
后端面试(Golang)可能会碰上的附加智力题
photoshop智能对象使用经验技巧
联想智能插线板常见问题介绍
内存都是由半导体器件构成的_开启5G新时代——XPS成像技术在半导体器件中的应用...
photoshop智能美肤后期修图教程
笔记本电脑系统下光驱没有盘符或打红叉解决办法
vscode和python是什么
Golang垃圾回收机制
Go GC垃圾回收机制
Golang基础第五篇——golang的gRPC
[关闭]