p1484 種樹

傳送門

題目

cyrcyr今天在種樹,他在一條直線上挖了n個坑。這n個坑都可以種樹,但為了保證每一棵樹都有充足的養料,cyrcyr不會在相鄰的兩個坑中種樹。而且由于cyrcyr的樹種不夠,他至多會種k棵樹。假設cyrcyr有某種神能力,能預知自己在某個坑種樹的獲利會是多少(可能為負),請你幫助他計算出他的最大獲利。

輸入格式:

第一行,兩個正整數n,k。

第二行,n個正整數,第i個數表示在直線上從左往右數第i個坑種樹的獲利。

輸出格式:

輸出1個數,表示cyrcyr種樹的最大獲利。

分析

首先我們先考慮k=1的情況,則答案即為所有數的最大值。然后我們在考慮k=2的情況,這是我們有兩種選擇:1.在選擇原本的所有數中的最大值ai的同時選一個與它不相鄰的數aj;2.不選擇ai,而選擇ai-1和ai+1。我們推而廣之便可以得到這個題的策略:每一次選堆中最大的元素,將以這個元素為中心的li和ri將會產生的影響放入堆中(因為以某點為中心可能不止向兩側擴展一次,所以要用lr數組記錄),我們要注意每次產生的影響是ali+ari-ai,因為這樣下一次選這兩個點便可以將其上一次擴展的影響覆蓋了。注意每一次擴展的lr要打一個標記以防止被以其他點為中心的點二次訪問,每一次更新lr也要注意將其更新成lli和rri,因為某點的左右邊界的點也可能擴展過。最后我們要注意如果哪一次堆頂元素為非正數就代表這之后任何擴展都不能給答案帶來正效應了,直接跳出循環即可。

代碼

#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<cctype>
#include<cmath>
#include<cstdlib>
#include<queue>
#include<ctime>
#include<vector>
#include<set>
#include<map>
#include<stack>
using namespace std;
#define f first
#define s second
long long a[600000],used[600000],l[600000],r[600000];
priority_queue<pair<long long,long long> >q;
inline void read(long long &x){long long f=1;x=0;char s=getchar();while(s<'0'||s>'9'){if(s=='-')f=-1;s=getchar();}while(s>='0'&&s<='9'){x=x*10+(s-'0');s=getchar();}x*=f;
}
int main()
{     long long n,m,i,j,k;read(n),read(m);for(i=1;i<=n;i++){read(a[i]);q.push(make_pair(a[i],i));l[i]=i-1;r[i]=i+1;}long long ans=0;while(m--){while(used[q.top().s])q.pop();long long x=q.top().f,y=q.top().s;q.pop();if(x<0)break;ans+=x;a[y]=a[l[y]]+a[r[y]]-x;used[l[y]]=used[r[y]]=1;l[y]=l[l[y]];r[l[y]]=y;r[y]=r[r[y]];l[r[y]]=y;q.push(make_pair(a[y],y));}printf("%lld\n",ans);return 0;
}

轉載于:https://www.cnblogs.com/yzxverygood/p/9135042.html

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

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

相關文章

Dalsa線掃相機SDK開發-小試牛刀(1)

拿到了dalsa相機&#xff0c;可以用Sapera軟件配置相機&#xff0c;進行圖像采集。但是自己開發的話就得擼起袖子寫代碼了&#xff0c;查了兩篇不錯的博文&#xff0c;作為指導。 Sapera幫助文檔 - 《好好先生》專欄 - 博客頻道 - CSDN.NET http://blog.csdn.net/liubing8609/a…

用FFMPEG SDK進行視頻轉碼壓縮時解決音視頻不同步問題的方法(轉) PTS DTS

用FFMPEG SDK進行視頻轉碼壓縮的時候&#xff0c;轉碼成功后去看視頻的內容&#xff0c;發現音視頻是不同步的。這個的確是一個惱火的事情。我在用FFMPEG SDK做h264格式的FLV文件編碼Filter的時候就碰到了這個問題。經過研究發現&#xff0c;FFMPEG SDK寫入視頻的時候有兩個地方…

深度學習環境搭建(GPU)CUDA安裝(完全版)

文章目錄1、查詢電腦硬件2、環境搭建與軟件安裝1、安裝CUDA運算平臺軟件2、安裝cuDNN支持包3、配置環境變量3、驗證CUDA與cuDNN安裝前幾天在看深度學習。因為對深度學習不是很了解&#xff0c;在配置環境時走了許多彎路&#xff0c;也總是戰戰兢兢的。現在對深度學習的環境搭建…

Linux 中的文件壓縮與解壓

.tar tar xvf FileName.tar # 解壓 tar cvf FileName.tar DirName # 壓縮 .gz gunzip FileName.gz # 解壓 gzip -d FileName.gz # 解壓 gzip FileName # 壓縮 .tar.gz 和 .tgz tar zxvf FileName.tar.gz # 解壓 tar zcvf FileName.tar.gz DirName # 壓縮 .bz2 bzip2 -d FileNam…

Unity3D游戲開發之自由視角下的角色控制

秦元培的博客:http://blog.csdn.net/qinyuanpei/article/details/39125353 1&#xff0c;[Unity3D]Unity3D游戲開發之角色控制漫談 2&#xff0c;[Unity3D]Unity3D游戲開發之自由視角下的角色控制 3&#xff0c;[Unity3D]Unity3D游戲開發之仿仙劍奇俠傳角色控制效果 轉載于:h…

Pycharm用鼠標滾輪控制字體大小

一、pycharm字體放大的設置 File —> setting —> Keymap —>在搜尋框中輸入&#xff1a;increase —> Increase Font Size&#xff08;雙擊&#xff09; —> 在彈出的對話框中選擇Add Mouse Shortcut 在彈出的對話框中同時按住ctrl鍵和鼠標滾輪向上滑。 二、…

Halcon自定義函數封裝方法(全網最詳細)

文章目錄1、名詞解釋2、例子介紹1、處理原圖與任務&#xff1a;2、代碼與解析&#xff1a;3、Halcon函數封裝方式①明確需求②選取函數部分進行函數創建&#xff0c;更改函數接口③運行驗證與函數更改操作有網友說不太清楚這個halcon函數的封裝方法。今天寫個教程帖子&#xff…

ffmpeg庫音頻解碼示例

#include <stdio.h> #include <stdlib.h> extern "C"{// #include "avcodec.h" #include "avformat.h" } int main(char arg,char *argv[]) { char *filename "02.swf"; av_register_all();//注冊所有可…

SQL Where in list 問題

不過,這種做法有兩個缺陷1.Oracle In列表的數目有限制(1000)2.不能復用執行計劃,每次幾乎都是硬解析.3.In拼接可能存在SQL注入的風險

readn writen實現linux下socket緩沖區讀寫

socket上的read write 操作不同與一般的文件IO操作&#xff0c;socket上的用read write讀寫的字節數可能比要求的少,但這并不是錯誤&#xff0c;原因是socket的緩沖區可能已經達到了極限。此時所需要的就是再次調用read write 以寫入或輸出剩余的字符。這種情況在socket中很常見…

傅里葉變換進行缺陷檢測detect_indent_fft.hdev(源代碼與詳細解析)

文章目錄簡介程序解析處理結果預覽算法講解簡介 detect_indent_fft.hdev是halcon的示例程序&#xff0c;是傅里葉變換進行缺陷檢測的一個例子&#xff0c;主要是傅里葉變換在復雜背景下的缺陷檢測。 這個程序展示了如何利用快速傅里葉變換&#xff08;FFT&#xff09;對塑料制…

lua環境搭建

前言 Linux & Mac上安裝 Lua 安裝非常簡單&#xff0c;只需要下載源碼包并在終端解壓編譯即可&#xff0c;本文介紹Linux 系統上&#xff0c;lua5.3.0版本安裝步驟&#xff1a; Linux 系統上安裝 [rootgitlab ~]# mkdir /app/tools/lua -p [rootgitlab ~]# cd /app/tools/l…

八、job管理

查看用法&#xff1a; [rootsuper65 ~]# salt-run -d|grep jobsjobs.active:                      #查看當前執行的job Return a report on all actively running jobs from a job id centric salt-run jobs.activejobs.list_job: salt-run jobs.list_j…

pthread_join/pthread_exit用法實例

函數pthread_join用來等待一個線程的結束。函數原型為&#xff1a;   extern int pthread_join __P ((pthread_t __th, void **__thread_return));   第一個參數為被等待的線程標識符&#xff0c;第二個參數為一個用戶定義的指針&#xff0c;它可以用來存儲被等待線程的返回…

thinkphp5 內置接口開發與使用

最近的一個項目在用tp5&#xff0c;對于tp3都幾乎沒用過的我來說~~~ tp5最好的一點就是對接口的單獨封裝&#xff0c;只要嚴格按照要求一步一步來就可以成功了 開啟命令行&#xff1a;配置環境變量安裝tp5項目cmd進入項目目錄&#xff0c;運行php think&#xff0c;出現如下內容…

Halcon2019軟件安裝教程

文章目錄1、halcon介紹2、安裝halcon-19.11.0.0-windows.exe1、下載halcon-19.11.0.0-windows.exe安裝包2、halcon-19.11.0.0-windows.exe軟件安裝3、驗證Halcon安裝1、halcon介紹 HALCON是德國MVtec公司開發的一套完善的標準的機器視覺算法包&#xff0c;擁有應用廣泛的機器視…

爬蟲常用庫的安裝

請求庫(requests,selenium)、解析庫(beautifulsop)、存儲庫、工具庫等 urelib re 上面這兩個是python自帶的庫 需要自己安裝額庫&#xff1a; (在windows下&#xff0c;使用pip install 命令) requests selenium用來驅動瀏覽器&#xff0c;做自動化測試&#xff0c;一些被js…

Python: 編程遇到的一些問題以及網上解決辦法?

0.Python: TypeError: str does not support the buffer interface,(點我) fp.write(url.encode("utf-8")) 1.Python:object of type Response has no len()&#xff0c;如何解決&#xff1f;(點我) Traceback (most recent call last):File "F:/Python/TD.py&q…

快排簡要介紹

<!DOCTYPE html><html lang"en"><head> <meta charset"UTF-8"> <title>Title</title></head> <body> <script> var arr [6,10,2,9,3,8,11,4,5]; function quickSort(data, start, end) { // 確定要…

在django中使用celery

前言: 針對高延時任務, 直接在一次網絡請求中處理完畢會導致很不好的體驗, celery則可以不阻塞請求后臺處理這些任務, 并且可以使用django的models進行數據庫操作.環境 python models: celery-4.1.1redis-2.10.6django-1.11.7其他: redis-3.2.9macospython3.6創建django工程 dj…