[codevs1105][COJ0183][NOIP2005]過河

[codevs1105][COJ0183][NOIP2005]過河

試題描述

在河上有一座獨木橋,一只青蛙想沿著獨木橋從河的一側跳到另一側。在橋上有一些石子,青蛙很討厭踩在這些石子上。由于橋的長度和青蛙一次跳過的距離都是正整數,我們可以把獨木橋上青蛙可能到達的點看成數軸上的一串整點:0,1,……,L(其中L是橋的長度)。坐標為0的點表示橋的起點,坐標為L的點表示橋的終點。青蛙從橋的起點開始,不停的向終點方向跳躍。一次跳躍的距離是S到T之間的任意正整數(包括S,T)。當青蛙跳到或跳過坐標為L的點時,就算青蛙已經跳出了獨木橋。
題目給出獨木橋的長度L,青蛙跳躍的距離范圍S,T,橋上石子的位置。你的任務是確定青蛙要想過河,最少需要踩到的石子數。

輸入

輸入第一行有一個正整數L(1<=L<=109),表示獨木橋的長度。第二行有三個正整數S,T,M,分別表示青蛙一次跳躍的最小距離,最大距離,及橋上石子的個數,其中1<=S<=T<=10,1<=M<=100。第三行有M個不同的正整數分別表示這M個石子在數軸上的位置(數據保證橋的起點和終點處沒有石子)。所有相鄰的整數之間用一個空格隔開。

輸出

輸出只包括一個整數,表示青蛙過河最少需要踩到的石子數。

輸入示例

10
2 3 5
2 3 5 6 7

輸出示例

2

數據規模及約定

對于30%的數據,L<=10000;
對于全部的數據,L<=109

題解

L 比較小時,可以直接 dp:設 f(i) 表示到達位置 i 時最少踩過的石子數目。正解與它做法一樣,只是發現許多節點是不需要考慮的,所以我們可以忽略它們。暴力找一下 S, T 分別取 1~10 時的最大不可表數,發現只有 71,那么當相鄰兩個石子間距離超過 71 時,我們就可以將這個距離變成它對 71 取模再加上 2 倍的 71,最后暴力 dp 一下就好了。注意判斷 S = T 的情況。

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cctype>
#include <algorithm>
using namespace std;int read() {int x = 0, f = 1; char c = getchar();while(!isdigit(c)){ if(c == '-') f = -1; c = getchar(); }while(isdigit(c)){ x = x * 10 + c - '0'; c = getchar(); }return x * f;
}#define maxn 27280
int L, S, T, n, A[maxn], f[maxn];
bool has[maxn];void up(int& a, int b) {if(a < 0) a = b;else a = min(a, b);return ;
}int main() {L = read(); S = read(); T = read(); n = read();for(int i = 1; i <= n; i++) A[i] = read();sort(A + 1, A + n + 1);if(S == T) {int cnt = 0;for(int i = 1; i <= n; i++) if(A[i] % S == 0) cnt++;return printf("%d\n", cnt), 0;}int p = 0;for(int i = 1; i <= n; i++)if(A[i] - A[i-1] <= 71) p += A[i] - A[i-1], has[p] = 1;else p += (A[i] - A[i-1]) % 71 + 142, has[p] = 1;memset(f, -1, sizeof(f));f[0] = 0;for(int i = 0; i <= p + 1; i++) if(f[i] >= 0)for(int j = S; j <= T; j++) {int tmp = (i + j <= p + 1) ? i + j : p + 1;up(f[tmp], f[i] + has[tmp]);}printf("%d\n", f[p+1]);return 0;
}

?

轉載于:https://www.cnblogs.com/xiao-ju-ruo-xjr/p/6165697.html

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

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

相關文章

ABB機器人套接口通信 機器人部分

ABB機器人套接口通信 機器人部分 文章機器人部分&#xff0c;描述如何運行機器人從機程序&#xff0c;使機器人根據上位機節點發送的命令&#xff0c;執行具體運動。 ABB機器人執行3個任務。這些任務都配置為SEMISTATIC(背景程序)的任務,第三任務是正常動作任務。下文描述如…

CRM項目總結

CRM項目總結 一&#xff1a;開發背景 在公司日益擴大的過程中&#xff0c;不可避免的會伴隨著更多問題出現。 對外 &#xff1a; 如何更好的管理客戶與公司的關系&#xff1f;如何更及時的了解客戶日益發展的需求變化&#xff1f;公司的產品是否真的符合客戶需求&#xff1f;以…

【面經——《速騰聚創科技有限公司——深度學習算法工程師》】

自我介紹 實習項目 1&#xff09;項目主要應用的領域&#xff1f; 2&#xff09;難點在哪&#xff1f;——機械臂吸盤大小和目標大小之間坐標的協調 3&#xff09;難點不在于算法&#xff0c;在于數據的處理和均衡性&#xff1f;對于數據均衡方面有什么理解&#xf…

js變量和數據類型

轉載于:https://www.cnblogs.com/songyinan/p/6181421.html

offline .net3.5

1.加載虛擬光驅 2.dism.exe /online /enable-feature /featurename:netfx3 /Source:D:\sources\sxs轉載于:https://www.cnblogs.com/BillLei/p/5294082.html

(九)模板方法模式詳解(包含與類加載器不得不說的故事)

作者&#xff1a;zuoxiaolong8810&#xff08;左瀟龍&#xff09;&#xff0c;轉載請注明出處&#xff0c;特別說明&#xff1a;本博文來自博主原博客&#xff0c;為保證新博客中博文的完整性&#xff0c;特復制到此留存&#xff0c;如需轉載請注明新博客地址即可。 模板方法模…

阿里云openapi接口使用,PHP,視頻直播

1.下載sdk放入項目文件夾中 核心就是aliyun-php-sdk-core&#xff0c;它的配置文件會自動加載相應的類 2.引入文件 include_once LIB_PATH . ORG/aliyun-openapi/aliyun-php-sdk-core/Config.php; 3.配置客戶端對象,需要Access Key ID,Access Key Secret $iClientProfile Defa…

【面經——《廣州敏視數碼科技有限公司》——圖像處理算法工程師-深度學習方向】

目錄 筆試 HR面 專業面——60多分鐘 主管面 反問&#xff1a; 筆試 8道題——簡答題 1道編程 蘋果、香蕉、梨、菠蘿&#xff0c;彩色圖像如何進行分類&#xff1f;一輛帶車牌的汽車&#xff0c;圖像亮度整體呈現偏亮狀態&#xff0c;如何…

Android之網絡編程利用PHP操作MySql插入數據(四)

因為最近在更新我的項目&#xff0c;就想著把自己在項目中用到的一些的簡單的與網絡交互的方法總結一下&#xff0c;所以最近Android網絡編程方面的博文會比較多一些&#xff0c;我盡量以最簡單的方法給大家分享&#xff0c;讓大家明白易懂。如果有什么不對的地方&#xff0c;還…

RAPID 信號的互鎖和同步 WaitTestAndSet 和 TestAndSet

RAPID 信號的互鎖和同步 WaitTestAndSet 指令等待指定的持久型 BOOL 變量變成 FALSE.當變量值變為 FALSE, 該指令將設置變量為 TRUE 并繼續執行. 該持久型變量可被作為同步或者互斥時的一個 BOOL 信號量。 這個指令與 TestAndSet 有著同樣的基本功能。但是 WaitTestAnd…

【常用網址】——opencv等

opencv官網Releases - OpenCVhttps://opencv.org/releases/

(五):C++分布式實時應用框架——微服務架構的演進

C分布式實時應用框架——微服務架構的演進 技術交流合作QQ群&#xff1a;436466587 歡迎討論交流 上一篇&#xff1a;(四)&#xff1a;C分布式實時應用框架——狀態中心模塊 版權聲明:本文版權及所用技術歸屬smartguys團隊所有&#xff0c;對于抄襲&#xff0c;非經同意轉載等…

如何通過軟件項目開發來提高自身的實力。

在我們這個專業&#xff0c;大多數人都不會將軟件開發當作自己的事業&#xff0c;因為若要在這個行業上能夠立足&#xff0c;得需要一個好的基礎&#xff0c;但是由于這個東西并不是可以通過書本能夠徹底的理解和 掌握的&#xff0c;隨著時間的變化&#xff0c;我們身邊的科技也…

夢回JavaScript--數據類型之undefined

undefined類型只有一個值&#xff0c;即undefined。在使用var聲明變量但未對其加以初始化時&#xff0c;這個變量的值就是undefined&#xff1b; var mes; alert(mes undefined) //true如果變量沒有聲明就會出現錯誤 var mes; alert(mes) //undefined alert(a)//error 然而有一…

Robot Application Builder

軟件開發工具包 Robot Application Builder是安裝在PC機&#xff08;Windows 2000或Windows XP操作系統&#xff09;上的一種獨立開發工具&#xff0c;可用于創建運行于ABB FlexPendant示教器或PC機上的定制化操作界面。為此&#xff0c;該軟件包由以下兩部分組成&#xff1a;…

asp.net model 驗證和取出 ErrorMessage 信息

為什么80%的碼農都做不了架構師&#xff1f;>>> public class Users{public int Id { get; set; }public string Name { get; set; }[Required(ErrorMessage "郵箱不能為空")][EmailAddressAttribute(ErrorMessage "郵箱格式不正確")]public…

this

作者&#xff1a;李挺鏈接&#xff1a;https://www.zhihu.com/question/19636194/answer/123274198來源&#xff1a;知乎著作權歸作者所有&#xff0c;轉載請聯系作者獲得授權。關于 this 的描述&#xff0c;曾經在 stackoverflow 上看到了一篇回答寫的非常詳盡&#xff0c;下面…

DeviceNet 消息類型

DeviceNet是一種低成本的通訊總線鏈接&#xff0c;具有開放現場網絡標準&#xff0c;規范和協議都是開放的。DeviceNet將控制和數據融合在一起&#xff0c;信息具有數據標識區&#xff0c;網絡利用標識區進行優先級仲裁&#xff0c;可以高效傳送I/O數據。 DeviceNet有兩種不同類…

【pyqt5學習——信號與槽】實例計時器(解決界面卡頓問題)

目錄 一、方法一&#xff1a;另開線程 1、什么是信號與槽 1&#xff09;GUI控件&#xff08;信號&#xff09;與槽 2&#xff09;自定義信號與槽 2、實戰1&#xff1a;計時器&#xff08;不自定義信號槽和不使用多線程&#xff09; 1&#xff09;界面設計——利用qt-desi…