日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

leetcode--1025. 除数博弈

發(fā)布時(shí)間:2024/2/28 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 leetcode--1025. 除数博弈 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

愛(ài)麗絲和鮑勃一起玩游戲,他們輪流行動(dòng)。愛(ài)麗絲先手開(kāi)局。

最初,黑板上有一個(gè)數(shù)字?N?。在每個(gè)玩家的回合,玩家需要執(zhí)行以下操作:

  • 選出任一?x,滿足?0 < x < N?且?N % x == 0?。
  • 用?N - x?替換黑板上的數(shù)字?N?。

如果玩家無(wú)法執(zhí)行這些操作,就會(huì)輸?shù)粲螒颉?/p>

只有在愛(ài)麗絲在游戲中取得勝利時(shí)才返回?True,否則返回?false。假設(shè)兩個(gè)玩家都以最佳狀態(tài)參與游戲。

?

示例 1:

輸入:2 輸出:true 解釋:愛(ài)麗絲選擇 1,鮑勃無(wú)法進(jìn)行操作。

示例 2:

輸入:3 輸出:false 解釋:愛(ài)麗絲選擇 1,鮑勃也選擇 1,然后愛(ài)麗絲無(wú)法進(jìn)行操作。

?

提示:

  • 1 <= N <= 1000
  • Colay

    • 如果N是奇數(shù),因?yàn)槠鏀?shù)的所有因數(shù)都是奇數(shù),因此 N 進(jìn)行一次 N-x 的操作結(jié)果一定是偶數(shù),所以如果 a 拿到了一個(gè)奇數(shù),那么輪到 b 的時(shí)候,b拿到的肯定是偶數(shù),這個(gè)時(shí)候 b 只要進(jìn)行 -1, 還給 a 一個(gè)奇數(shù),那么這樣子b就會(huì)一直拿到偶數(shù),到最后b一定會(huì)拿到最小偶數(shù)2,a就輸了。

    • 所以如果游戲開(kāi)始時(shí)Alice拿到N為奇數(shù),那么她必輸,也就是false。如果拿到N為偶數(shù),她只用 -1,讓bob 拿到奇數(shù),最后bob必輸,結(jié)果就是true。

    class Solution { public:bool divisorGame(int N) {if(N%2==0) return true;else return false;} };

    動(dòng)態(tài)規(guī)劃版本:

    class Solution {public boolean divisorGame(int N) {boolean[] dp = new boolean[N + 1];dp[1] = false;for (int i = 2; i <= N; i++) {for (int j = 1; j < i; j++) {if (i % j == 0 && dp[i - j] == false) {dp[i] = true;}}}return dp[N];} }

    ?

    總結(jié)

    以上是生活随笔為你收集整理的leetcode--1025. 除数博弈的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。