「POJ2505」A multiplication game [博弈論]

来源:https://www.cnblogs.com/justin-cao/archive/2018/02/18/8452854.html
-Advertisement-
Play Games

題目鏈接:http://poj.org/problem?id=2505 題目大意: 兩個人輪流玩游戲,Stan先手,數字 p從1開始,Stan乘以一個2-9的數,然後Ollie再乘以一個2-9的數,直到誰先將p乘到p>=n時那個人就贏了,而且輪到某人時,某人必須乘以2-9的一個數。 解題思路: 這是 ...


題目鏈接:http://poj.org/problem?id=2505

題目大意:

兩個人輪流玩游戲,Stan先手,數字 p從1開始,Stan乘以一個2-9的數,然後Ollie再乘以一個2-9的數,直到誰先將p乘到p>=n時那個人就贏了,而且輪到某人時,某人必須乘以2-9的一個數。

解題思路:

這是一道博弈論的題目。
不過這道題並沒有用SG函數相關的知識。
首先我們可以很快判斷區間[2,9]必定是先手勝
然後緊接著是區間[10,18]區間是後手勝
然後是什麼呢?
[18,??]
我們可以這樣來理解:
我們可以考慮一下,先手是要取勝,就是要越大越好,越大越快,
所以每次輪到先手進行操作時,肯定是要乘上最大的哪一個數,也就是9
那麼我們反過來,後手就是要儘量拖住先手,所以每一次都會乘上哪一個最小的數,也就是2
於是,這樣的話我們就可以將區間補出來:
[2,9]
[9+1,9*2]
[9*2+1,9*2*9]
[9*2*9+1,9*2*9*2]
.......
所以著一道題我們就可以做了吧。
至於怎麼操作,我用的方法並不是最快的,但是應該是比較清楚的。
定義l,r為2,9然後按照上面模擬即可,然後每次判斷就行
額。。。網上有題解說他們是找規律找出來的,我連找規律都不會找。。。。。推了好久才推出來。。。
無語。。。
貼代碼:

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 using namespace std;
 5 typedef long long ll;
 6 ll n;
 7 int main()
 8 {
 9     while(scanf("%lld",&n)==1)
10     {
11         ll l=2;
12         ll r=9;
13         int flag=1;
14         while(true)
15         {
16             if(n>=l&&n<=r)
17             {
18                 if(flag==1)  printf("Stan wins.\n");
19                 else         printf("Ollie wins.\n");
20                 break;
21             }
22             else{
23                 l=r+1;
24                 if(flag==1) 
25                 {
26                     r=r*2;
27                     flag=0;
28                 } 
29                 else
30                 {
31                     flag=1;
32                     r=r*9;
33                 }
34             }
35         }
36     }
37     return 0;
38 }

謝謝大家支持。

如何可以指出我有哪些寫得不好的地方,本人感激不盡!!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 兩個實體類:客戶與聯繫人,一個客戶可以有多個聯繫人 客戶類: package domain; import java.util.HashSet; import java.util.Set; //客戶實體 public class Customer { private Long cust_id; pr ...
  • 我們以 printf 這個 very 熟悉的函數為例,來分析一下變參函數。先看下 printf 函數的定義: ~~~~ int printf(const char fmt, ...) { int i; int len; / va_list 即 char / va_list args; va_star ...
  • 2、xml配置文件: 3、實例對象: 4、BeanFactory工廠: ...
  • Python urllib urlretrieve函數解析 利用urllib.request.urlretrieve函數下載文件 覺得有用的話,歡迎一起討論相互學習~ "Follow Me" 參考文獻 "Urlretrieve函數解析" urllib.request.urlretrieve函數解析 ...
  • 一、攔截器 1.概述 ​ 在struts2中,攔截器(Interceptor)是用來動態攔截Action執行的對象。 ​ 攔截器有點類似以前Servlet階段的Filter(過濾器) , 能夠在請求到達Action之前進行攔截操作, 可以在裡面進行判斷校驗。 典型的例子: 登錄攔截. 註:過濾器可以 ...
  • 拖了這麼久,最終還是戰勝了懶惰,打開電腦寫了這篇博客,內容也很簡單,python實現字元串轉整型的int方法 python已經實現了int方法,我們為什麼還要再寫一遍,直接用不就好了?事實確實如此,但是int函數看似簡單,實際上自己來實現還是有一些坑的 1.判斷正負 這點很容易忘記 2.python ...
  • HQL查詢:hibernate獨有的查詢語言 適用於不複雜的多表查詢 示例: 實體類: package domain; public class Customer { private Long cust_id; private String cust_name; private String cus ...
  • 一、flask a、Flask是一個基於Python開發並且依賴jinja2模板和Werkzeug WSGI服務的一個微型框架,對於Werkzeug本質是Socket服務端,其用於接收http請求並對請求進行預處理,然後觸發Flask框架,開發人員基於Flask框架提供的功能對請求進行相應的處理,並 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...