4396 取石子(思维题)

1. 问题描述:

两个小朋友玩取石子游戏。第一个小朋友面前有 n1 个石子,第二个小朋友面前有 n2 个石子。两人轮流取自己面前的石子。第一个小朋友先手,第二个小朋友后手。第一个小朋友每轮次最多取 k1 个石子,最少取 1 个石子。第二个小朋友每轮次最多取 k2 个石子,最少取 1 个石子。率先取完自己面前石子的小朋友,视为失败。请问,两个小朋友都采取最优策略的情况下,谁会获胜?

输入格式

一行,四个整数 n1,n2,k1,k2;

输出格式

如果第一个小朋友获胜,则输出 First,如果第二个小朋友获胜,则输出 Second;

数据范围

所有测试点满足 1 ≤ n1,n2,k1,k2 ≤ 50;

输入样例1:

2 2 1 2

输出样例1:

Second

输入样例2:

2 1 1 1

输出样例2:

First
来源:https://www.acwing.com/problem/content/description/4399/

2. 思路分析:

分析题目可以知道最先取完石子的人视为失败,由于两个人都是选择最优的策略所以每次肯定是取一个石子,分情况讨论即可, 当 n1 > n2 的时候第一个人作为先手那么肯定是第二个人先取完,第一个人赢,当 n1 = n2 的时候第一个人作为先手那么是第一个人先取完,那么第二个人赢,对于 n1 < n2 第一个人作为先手肯定是第一个人先取完所以第二个人赢。

3. 代码如下:

python:

if __name__ == "__main__":
    n1, n2, k1, k2 = map(int, input().split())
    if n1 > n2: print("First")
    else: print("Second")

go:

package main

import "fmt"

func main() {
	var (
		n1, n2, k1, k2 int
	)
	fmt.Scan(&n1, &n2, &k1, &k2)
	if n1 > n2 {
		fmt.Println("First")
	} else {
		fmt.Println("Second")
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值