首页 > 其他 > 详细

LintCode之硬币排成线

时间:2017-11-06 19:42:24      阅读:202      评论:0      收藏:0      [点我收藏+]

技术分享

 

输入的n可以分为两种情况:

1. 如果n是3的倍数的话,不论A怎么拿B都可以拿(3-A拿的个数)来使其保持是3的倍数,他就一定能拿到最后一块,所以n是3的倍数的话B必胜

2. 如果n不是3的倍数的话,那么A就能够拿1或者2块使其变为3的倍数,就相当于B变成了第一种情况中的A,所以n不是3的倍数的话A必胜

 

AC代码:

class Solution:
    """
    @param: n: An integer
    @return: A boolean which equals to true if the first player will win
    """
    def firstWillWin(self, n):
        # write your code here
        return True if n % 3 is not 0 else False

 

 

参考资料:

1. http://www.lintcode.com/zh-cn/problem/coins-in-a-line/

LintCode之硬币排成线

原文:http://www.cnblogs.com/cc11001100/p/7794664.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!