C++洛谷P1002 過河卒

題目

鏈接:https://www.luogu.com.cn/problem/P1002

?解析

這道題適用于了解動態規劃的同學。

變量初始化

初始化B點坐標(n, m)和馬的坐標(a, b)

初始化方向數組和動態規劃數組

long long dp[30][30];
int dx[8] = {-2, -2, -1, -1, 1, 1, 2, 2};
int dy[8] = {1, -1, 2, -2, 2, -2, 1, -1};
int n, m, a, b;

輸入部分

輸入n,m,a,b。

 cin >> n >> m >> a >> b;

運算部分

初始化

初始化dp數組。

dp[0][0] = 1;
for (int i = 0; i < 8; i ++) {int x = a + dx[i], y = b + dy[i];if (x >= 0 && x <= n && y >= 0 && y <= m)dp[x][y] = -1;
}
dp[a][b] = -1;

首先到達自己的點的坐標dp[0][0]肯定只有一種方法,那就是原地不動。

循環方向數組,把那些馬可能到的地方給標記一下。

馬的地方不能走,設為-1。

推導式

由于卒只能從上面或者左面過來,所以得出dp[i][j] = dp[i - 1][j] + dp[i][j - 1]

如果遍歷到馬的話直接設為0,要不然在算的時候直接-1。

dp代碼

for (int i = 0; i <= n; i ++)for (int j = 0; j <= m; j ++)if (dp[i][j] == -1)dp[i][j] = 0;else {if (i - 1 >= 0)dp[i][j] += dp[i - 1][j];if (j - 1 >= 0)dp[i][j] += dp[i][j - 1];}

輸出

直接輸出就可以了。

cout << dp[n][m] << endl;

代碼

#include <iostream>
using namespace std;
long long dp[30][30];
int dx[8] = {-2, -2, -1, -1, 1, 1, 2, 2};
int dy[8] = {1, -1, 2, -2, 2, -2, 1, -1};
int main() {int n, m, a, b;cin >> n >> m >> a >> b;dp[0][0] = 1;for (int i = 0; i < 8; i ++) {int x = a + dx[i], y = b + dy[i];if (x >= 0 && x <= n && y >= 0 && y <= m)dp[x][y] = -1;}dp[a][b] = -1;for (int i = 0; i <= n; i ++)for (int j = 0; j <= m; j ++)if (dp[i][j] == -1)dp[i][j] = 0;else {if (i - 1 >= 0)dp[i][j] += dp[i - 1][j];if (j - 1 >= 0)dp[i][j] += dp[i][j - 1];}cout << dp[n][m] << endl;return 0;
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/86784.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/86784.shtml
英文地址,請注明出處:http://en.pswp.cn/web/86784.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

BlogX項目Go-gin--根據IP獲取地理位置

先定義一個函數來判斷IP地址是否為內網&#xff0c;歸為工具類 // utils/ip/enter.go package ipimport "net"func HasLocalIPAddr(ip string) bool {return HasLocalIP(net.ParseIP(ip)) }// HasLocalIP 檢測 IP 地址是否是內網地址 // 通過直接對比ip段范圍效率更…

鴻蒙系統(HarmonyOS)應用開發之實現瀑布流圖片展示效果

項目概述 科技圖庫是一款基于鴻蒙系統&#xff08;HarmonyOS&#xff09;開發的高品質圖片瀏覽應用&#xff0c;專注于展示精選科技主題圖片。應用采用現代化的瀑布流布局&#xff0c;為用戶提供流暢、直觀的瀏覽體驗&#xff0c;讓科技之美盡收眼底。 主要功能 1. 瀑布流布…

【fish-speech】新模型openaudio-s1-mini嘗鮮

一、配置 顯卡&#xff1a;v100&#xff08;測試簡短語句&#xff0c;顯存實際占用不足6G&#xff09; 二、安裝測試 1. 安裝 1.1 下載源碼 git clone https://github.com/fishaudio/fish-speech.git1.2 安裝系統組件 apt install portaudio19-dev libsox-dev ffmpeg1.3 …

介紹Windows下的由Sysinternals開發的一些小工具

Sysinternals是一個開發了很多Windows下系統工具的公司&#xff0c;這些工具能極大地提高對Windows系統的深入認知。就像它的名字Sys(tem)internals&#xff0c;深入系統里面。這些工具都放在微軟的網站上可以下載到。https://learn.microsoft.com/en-us/sysinternals/ 下載網…

云服務器環境下Linux系統epoll機制與高并發服務器優化實踐

在當今云計算時代&#xff0c;云已成為企業部署高并發服務的首選平臺。本文將深入探討Linux系統核心的epoll機制如何賦能云環境下的高并發服務器&#xff0c;解析其底層工作原理與性能優勢&#xff0c;并對比傳統IO復用模型的差異&#xff0c;幫助開發者構建更高效的云端服務架…

Java爬蟲實戰指南:按關鍵字搜索京東商品

在電商領域&#xff0c;快速獲取商品信息對于市場分析、選品上架、庫存管理和價格策略制定等方面至關重要。京東作為國內領先的電商平臺之一&#xff0c;提供了豐富的商品數據。雖然京東開放平臺提供了官方API來獲取商品信息&#xff0c;但有時使用爬蟲技術來抓取數據也是一種有…

aspose.word在IIS后端DLL中高并發運行,線程安全隔離

aspose.word在IIS后端DLL中運行,加載很慢,如何為全部用戶加載,再每個用戶訪問時在各自線程中直接可以打開WORD文件處理 Aspose.Words 在 IIS 中優化加載性能方案 針對 Aspose.Words 在 IIS 后端 DLL 中加載緩慢的問題&#xff0c;我們可以通過單例模式預加載組件并結合線程安…

鏈表題解——回文鏈表【LeetCode】

一、算法邏輯&#xff08;通順講解每一步思路&#xff09; 我們從 isPalindrome 這個主函數入手&#xff1a; 步驟 1&#xff1a;找到鏈表的中間節點 middleNode 使用 快慢指針法&#xff08;slow 和 fast&#xff09; 快指針一次走兩步&#xff0c;慢指針一次走一步。 當快…

allegro 銅皮的直角邊怎么快速變成多邊形?

像這種&#xff1a; 變成這種&#xff1a; 解決方案&#xff1a; shape edit boundary 點擊鋪銅邊緣就能裁剪

從廚房到代碼臺:用做菜思維理解iOS開發 - Swift入門篇②

從廚房到代碼臺&#xff1a;用做菜思維理解iOS開發 - Swift入門篇② 本章重點? 理解App開發的整體流程熟悉Xcode主界面結構與常用分區跟著步驟動手創建第一個App項目&#xff0c;認識模擬器掌握"打掃廚房"高頻快捷鍵&#xff0c;解決常見疑難雜癥 1、目標 像一個專…

EloqCloud for KV 初體驗:兼容redis的云原生KV數據庫

最近在做一些AI應用的時候&#xff0c;我在想嘗試利用redis的能力緩存一些信息&#xff0c;這使我想去找一個免費的redis來進行使用&#xff0c;在調研的過程中我發現了一款產品EloqCloud for KV可以提供類似的能力&#xff0c;于是嘗試使用了一下&#xff0c;本文記錄了這次體…

企業級路由器技術全解析:從基礎原理到實戰開發

簡介 在當今數字化時代,路由器作為網絡的核心設備,其技術深度與應用廣度直接影響著企業網絡的性能與安全性。本文將全面解析路由器的基礎原理、工作機制以及企業級開發技術,從網絡層尋址到路由協議算法,從安全配置到QoS實現,再到多廠商API開發實戰,旨在幫助網絡工程師和…

day041-web集群架構搭建

文章目錄 0. 老男孩思想-高薪四板斧1. web集群架構圖2. 搭建異地備份服務2.1 服務端-阿里云服務器2.1.1 查看rsync軟件包2.1.2 添加rsync配置文件2.1.3 添加虛擬用戶2.1.4 創建校驗用戶密碼文件2.1.5 創建備份目錄2.1.6 啟動服務2.1.7 開放安全組端口2.1.8 發送檢查郵件 2.2 客…

day44-Django RestFramework(drf)下

1.5 Django RestFramework(下) drf 內置了很多便捷的功能,在接下來的課程中會給大家依次講解下面的內容: 快速上手請求的封裝版本管理認證權限限流序列化視圖條件搜索分頁路由解析器10. 分頁 在查看數據列表的API中,如果 數據量 比較大,肯定不能把所有的數據都展示給用…

機器學習基礎 線性回歸與 Softmax 回歸

機器學習基礎 線性回歸與 Softmax 回歸 文章目錄 機器學習基礎 線性回歸與 Softmax 回歸1. 最小二乘法1.1 數據集定義1.2 最小二乘的矩陣推導1.3 最小二乘的幾何解釋1.4 概率視角下的最小二乘估計 2. 正則化2.1 L1 范數與 L2 范數2.2 正則化的作用2.3 Lasso 回歸的求解2.3.1 L-…

6.27_JAVA_面試(被抽到了)

1.MYSQL支持的存儲引擎有哪些, 有什么區別 ? In-no-DB&#xff08;默認&#xff09;&#xff1a;支持事務安全&#xff08;數據庫運行時&#xff0c;能保證數據的一致性、完整性&#xff09;&#xff0c;支持表行鎖&#xff0c;支持物理和邏輯外鍵。占用磁盤空間大。 MEMORY&…

YOLOv13震撼發布:超圖增強引領目標檢測新紀元

YOLOV13最近發布了&#xff0c;速速來看。 論文標題&#xff1a;YOLOv13&#xff1a;融合超圖增強的自適應視覺感知的實時目標檢測 論文鏈接&#xff1a;https://arxiv.org/pdf/2506.17733 代碼鏈接&#xff1a;https://github.com/iMoonLab/yolov13 話不多說&#xff0c;直…

Docker錯誤問題解決方法

1. Error response from daemon: Get “https://registry-1.docker.io/v2/”: net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers) https://zhuanlan.zhihu.com/p/24228872523 2. no configuration file provided: …

大模型在惡性心律失常預測及治療方案制定中的應用研究

目錄 一、引言 1.1 研究背景與意義 1.2 研究目的與方法 1.3 研究創新點 二、大模型技術概述 2.1 大模型基本原理 2.2 常見大模型類型及特點 2.3 大模型在醫療領域的應用現狀 三、心律失常的術前預測與準備 3.1 術前心律失常預測的重要性 3.2 大模型在術前預測中的應…

【視頻芯片選型】

一、邊緣 AI 芯片選型邏輯與未來趨勢 &#xff08;一&#xff09;嘉楠 K230、全志 V853、瑞芯微 RK3588 對比選型 核心場景適配 嘉楠 K230&#xff1a; 適合低功耗邊緣 AI場景&#xff0c;如智能家居中控&#xff08;支持語音 視覺雙模態交互&#xff09;、電池供電設備&#…