HDU4405 Aeroplane chess(期望dp)

来源:https://www.cnblogs.com/zwfymqz/archive/2018/08/24/9527783.html
-Advertisement-
Play Games

題意 抄襲自https://www.cnblogs.com/Paul-Guderian/p/7624039.html 正在玩飛行棋。輸入n,m表示飛行棋有n個格子,有m個飛行點,然後輸入m對u,v表示u點可以直接飛向v點,即u為飛行點。如果格子不是飛行點,扔骰子(1~6等概率)前進。否則直接飛到目標 ...


題意

抄襲自https://www.cnblogs.com/Paul-Guderian/p/7624039.html

正在玩飛行棋。輸入n,m表示飛行棋有n個格子,有m個飛行點,然後輸入m對u,v表示u點可以直接飛向v點,即u為飛行點。如果格子不是飛行點,扔骰子(1~6等概率)前進。否則直接飛到目標點。每個格子是唯一的飛行起點,但不是唯一的飛行終點。問到達或越過終點的扔骰子期望數。

從0出發!!

Sol

比較zz的期望dp

設$f[i]$表示從$i$出發,到達$n$的期望步數

轉移的時候討論一下即可

/*

*/
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<map>
#include<vector>
#include<set>
#include<queue>
#include<cmath>
#define Pair pair<int, int>
#define MP(x, y) make_pair(x, y)
#define fi first
#define se second
//#define int long long 
//#define getchar() (p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 1<<22, stdin), p1 == p2) ? EOF : *p1++)
//char buf[(1 << 22)], *p1 = buf, *p2 = buf;
using namespace std;
const int MAXN = 1e5 + 10, INF = 1e9 + 10;
const double eps = 1e-10;
inline int read() {
    char c = getchar(); int x = 0, f = 1;
    while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
    while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
    return x * f;
}
int N, M, to[MAXN];
double f[MAXN];
int main() {
    while(scanf("%d %d", &N, &M)) {
        if((N == 0) && (M == 0)) break;
        memset(to, 0, sizeof(to));
        memset(f, 0, sizeof(f));
        for(int i = 1; i <= M; i++) {
            int x = read(), y = read();
            to[x] = y;
        }
        for(int x = N - 1; x >= 0; x--) {
            if(to[x]) f[x] = f[to[x]];
            else {
                for(int j = 1; j <= 6; j++) f[x] += f[x + j];
                f[x] /= 6; f[x]++;
            }
        }
        printf("%.4lf\n", f[0]);
    }
    return 0;
}
/*

*/

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

-Advertisement-
Play Games
更多相關文章
  • 前言 之前幾個章節,大部分都是算介紹springboot的一些外圍配置,比如日誌配置等。這章節開始,開始總結一些關於springboot的綜合開發的知識點。由於SpringBoot本身是基於Spring和SpringMvc等各類spring家族的一個解決方案,可快速進行集合。故相關知識點其實大部分都 ...
  • 相關jar包分享:struts2+hibernate3+spring3 以及aop ,mysql,以及整合必須包。 鏈接:https://pan.baidu.com/s/1nCHmSsKU0hiV8DTj_V03sQ 密碼:29nf 在學習spring和hibernate的基礎後,試著將三大框架整合 ...
  • 推薦閱讀: 大數據智慧平臺落地方案 Nginx + 阿裡雲SSL + tomcat 實現https訪問代理 永遠別忘了TD 再確認測試代碼前,先找別人幫你檢查下是否無誤。在別人做之前儘量檢查出bug並且將其處理好。代碼審查最重要規則是對即將提交的代碼中查找問題——你需要做的就是確認代碼是正確的。 2 ...
  • 前不久做了一個優惠劵的分享功能,其中一個功能就是生成一個優惠劵分享短鏈接。生成的短鏈接要求每個鏈接都是唯一的,並且長度儘可能短。在網上查了一下相關的思路,發現了一個不錯的演算法。這個演算法的思路就是用[a-zA-Z0-9]建立一個長度為62的矩陣,然後把矩陣打亂,再生成一個全局唯一的數字,再把這個數字用 ...
  • Java設計模式之【工廠模式】(簡單工廠模式,工廠方法模式,抽象工廠模式) 工廠模式出現的原因 在java中,創建一個對象最簡單的方法就是使用new關鍵字。但在一些複雜的業務邏輯中,創建一個對象不只需要new一行代碼就成了,可能需要一些列的初始化設置,或先創建一些輔助對象來創建這個對象。 在這種場景 ...
  • 編碼及運算符 1.編碼 1.編碼的概念 在電腦硬體中,編碼(coding)是指用代碼來表示各組數據資料,使其成為可利用電腦進行處理和分析的信息。代碼是用來表示事物的記號,它可以用數字、字母、特殊的符號或它們之間的組合來表示。 2.編碼的種類(常用種類) ①ASCCI 1.ASCCI的產生 在計算 ...
  • 1.Solr的安裝 2.核心概念 1.Solr伺服器 >理解為資料庫 2.核 >表 3.field >表中欄位 3.創建核 1.在solr-home下創建一個目錄(目錄名隨意,例如t_item) 2.拷貝核中所需要的配置文件(solr-home下configsets裡面) : cp -r confi ...
  • Thymeleaf Thymeleaf是跟Velocity、FreeMarker類似的模板引擎,它可以完全替代JSP,相較與其他的模板引擎,它主要有以下幾個特點: 1. Thymeleaf在有網路和無網路的環境下皆可運行,即它可以讓美工在瀏覽器查看頁面的靜態效果,也可以讓程式員在伺服器查看帶數據的動 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...