编程题:串珠子

串珠子

题目地址:
http://www.nowcoder.com/question/next?pid=1597148&qid=44664&tid=3206491


描述

现在A和B在玩一个游戏,这个游戏首先给了他们很多珠子,珠子有两种颜色,一种蓝色,一种黄色,我们假定两种珠子都有无限多。A需要选择n颗珠子(n为奇数),然后由B串成一串项链(顺序由B确定,这里的项链也就是一个环)。假如在最后串成的项链中,A能够找到两个不同位置的蓝色珠子,并在这两处把这个项链断开成两段,其中一段恰好长度为(n+1)/2那么A就胜利了,注意这里为整数截断除法且这个长度是不包括选出的两颗珠子的。现在请你计算出A至少要选择多少颗蓝色珠子,才能保证无论B怎么串,他都能获胜。举个例子,当A选了7颗珠子,其中有3颗蓝珠子,那么如果B串的项链为”蓝蓝红红红红蓝”,则A能获胜,若B串的项链为”蓝蓝红红蓝红红”,则A不能获胜。


输入

给定一个整数n,为A要选出的珠子颗数.


输出

请返回A至少要选的蓝珠子颗数。


思路

先说结论

int find_k(int n) {
    if (0 == n%3) {
        return n / 2;
    } else {
        return (n+1) / 2;
    }   
}

证明如下
假如我是B,我会用最优方式串珠子,那么怎么串呢,如下图
图1
图1:我们如何串珠子( L=n121 )

假如我们第一个串蓝的(图中红色),那么,第L%n和第(n-L)%n一定不是能蓝珠子,相应的我们会在 2L%n 和 (2n-2L)%n 放红珠子(图中绿色)。

当n不是3的倍数的时候一切OK。
n=3k 时,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值