藍橋杯2117砍竹子(簡單易懂 包看包會版)

問題描述

這天, 小明在砍竹子, 他面前有?n?棵竹子排成一排, 一開始第?i?棵竹子的 高度為?hi?.

他覺得一棵一棵砍太慢了, 決定使用魔法來砍竹子。魔法可以對連續的一 段相同高度的竹子使用, 假設這一段竹子的高度為?H, 那么

用一次魔法可以 把這一段竹子的高度都變為??H2?+1?, 其中??x??表示對?x?向下取整。小明想 知道他最少使用多少次魔法可

讓所有的竹子的高度都變為 1 。

輸入格式

第一行為一個正整數?n, 表示竹子的棵數。

第二行共?n?個空格分開的正整數?hi, 表示每棵竹子的高度。

輸出格式

一個整數表示答案。

樣例輸入

6
2 1 4 2 6 7

?

樣例輸出

5

?

樣例說明

其中一種方案:

214262: 214267→214262→214222→211222→111222→111111?? ?共需要 5 步完成

評測用例規模與約定

對于?20%?的數據, 保證?n≤1000,hi≤106 。 對于?100%的數據, 保證?n≤2×105,hi≤1018 。

運行限制

  • 最大運行時間:2s
  • 最大運行內存: 256M
  • ?

解題思路

這是一道不需要思考思維 要求實現細節的貪心思維題目

首先 易得一個貪心策略:優先砍所剩竹子中高度最大的竹子??砍完高度高的竹子后由于高度變低,所以可能會跟原來高度低的竹子一塊被砍? 所以策略后半部分為?盡可能制造出多的高度相同的連續竹子? 然后一起砍

實現細節:會卡sqrt的精度 只能過65%的數據

每次利用堆取出? 并記錄下最高竹子的長度和編號 之后利用長度相同 編號相鄰的竹子一起砍一次的策略 只砍一次 依次入堆

AC代碼展示

如果覺得有用 就點贊+收藏 關注一下吧

#include <bits/stdc++.h>
#define IOS ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
#define endl '\n'
using namespace std;
typedef long long LL;
typedef pair<LL,int> PLI;
const int N=2e5+10;
int n;
LL x,res;
priority_queue<PLI> q;void solve(){while(!q.empty()){PLI t=q.top(); q.pop();LL t1=t.first; int t2=t.second;LL high=sqrtl(t1/2+1); //砍竹子//注意:此題會卡sqrt的精度 要用sqrtl 返回long doubleif(high!=1) q.push({high,t2});//其實也可以理解為 對連續且長度相同的樹的一列 就一起砍了 減少次數while(!q.empty()&&q.top().first==t1&&q.top().second==t2-1){t2--;q.pop();if(high!=1) q.push({high,t2}); //注意 放的時候 竹子的高度是砍過的 }res++; //出現高度不同或編號不連續 即不能連續砍時 就++一次 每次取出一顆樹 最后就會砍一次 只不過貪心一下是否可以一次多砍幾棵樹 }
}int main(){IOS;cin>>n;for(int i=0;i<n;i++){cin>>x;if(x!=1) q.push({x,i});} solve();cout<<res<<endl; return 0;
}

?

?

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

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

相關文章

如何進行 JavaScript 性能優化?

要進行 JavaScript 性能優化&#xff0c;我們可以從多個角度進行思考&#xff0c;主要包括減少頁面渲染時間、減少內存占用、優化代碼執行效率等。以下是優化的一些方法&#xff0c;并結合實際項目代碼示例講解。 目錄結構 減少 DOM 操作 緩存 DOM 元素批量更新 DOM 優化 Jav…

CTF-PWN: 全保護下格式化字符串利用 [第一屆“吾杯”網絡安全技能大賽 如果能重來] 賽后學習(不會)

通過網盤分享的文件&#xff1a;如果能重來.zip 鏈接: https://pan.baidu.com/s/1XKIJx32nWVcSpKiWFQGpYA?pwd1111 提取碼: 1111 --來自百度網盤超級會員v2的分享漏洞分析 格式化字符串漏洞,在printf(format); __int64 sub_13D7() {char format[56]; // [rsp10h] [rbp-40h]…

selenium-常見問題解決方案匯總

selenium-常見問題解決方案 selenium版本selenium代理本地瀏覽器頁面Selenium之多窗口句柄的切換 selenium版本 selenium版本為: 3.141.0 注&#xff1a;selenium4x跟selenium3x會有不同的使用方法&#xff0c; selenium代理本地瀏覽器頁面 利用 Selenium 庫實現對 Google C…

Flask使用長連接

Flask使用flask_socketio實現websocket Python中的單例模式 在HTTP通信中&#xff0c;連接復用&#xff08;Connection Reuse&#xff09;是一個重要的概念&#xff0c;它允許客戶端和服務器在同一個TCP連接上發送和接收多個HTTP請求/響應&#xff0c;而不是為每個新的請求/響…

雨晨 26100.2454 Windows 11 24H2 專業工作站 極簡純凈版

文件: 雨晨 26100.2454 Windows 11 24H2 專業工作站極簡 install.esd 大小: 1947043502 字節 修改時間: 2024年12月6日, 星期五, 16:38:37 MD5: 339B7FDCA0130D432A0E98957738A9DD SHA1: 2978AE0CEAF02E52EC4135200D4BDBC861E07BE8 CRC32: 8C329C89 簡述&#xff1a; 由YCDIS…

[docker中首次配置git環境與時間同步問題]

11月沒寫東西&#xff0c;12月初趕緊水一篇。 剛開始搭建docker服務器時&#xff0c;網上找一堆指令配置好git后&#xff0c;再次新建容器后忘記怎么配了&#xff0c;&#xff0c;這次記錄下。 一、git ssh指令法&#xff0c;該方法不用每次提交時輸入密碼 前期準備&#xff0…

MongoDB性能監控工具

mongostat mongostat是MongoDB自帶的監控工具&#xff0c;其可以提供數據庫節點或者整個集群當前的狀態視圖。該功能的設計非常類似于Linux系統中的vmstat命令&#xff0c;可以呈現出實時的狀態變化。不同的是&#xff0c;mongostat所監視的對象是數據庫進程。mongostat常用于…

linux下的python打包

linux下的python打包 一、pyinstaller 優點&#xff1a;打包簡單&#xff0c;將整個運行環境進行打包 缺點&#xff1a;打包文件大、臃腫、啟動慢 安裝pyinstaller包 pip install pyinstaller 打包一個文件 pyinstaller -D app.py會在當前路徑中生成build、dist文件夾還有…

Python模塊之random、hashlib、json、time等內置模塊語法學習

Python內置模塊語法學習 random、hashlib、json、time、datetime、os等內置模塊語法學習 模塊 簡單理解為就是一個.py后綴的一個文件 分為三種&#xff1a; 內置模塊&#xff1a;python自帶&#xff0c;可調用第三方模塊&#xff1a;別人設計的&#xff0c;可調用自定義模塊…

從ctfwiki開始的pwn之旅 5.ret2csu

ret2csu 原理 在 64 位程序中&#xff0c;函數的前 6 個參數是通過寄存器傳遞的&#xff0c;但是大多數時候&#xff0c;我們很難找到每一個寄存器對應的 gadgets。 這時候&#xff0c;我們可以利用 x64 下的 __libc_csu_init 中的 gadgets。這個函數是用來對 libc 進行初始…

Ceph對象存儲

Ceph對象存儲1.概念對象存儲&#xff08;Object Storage&#xff09;是一種用于存儲大量非結構化數據的架構模型它使用簡單的HTTP或HTTPS協議進行文件訪問&#xff0c;而不是傳統的文件系統API與傳統的文件系統存儲方式不同&#xff0c;對象存儲不是將數據存儲在目錄或文件夾中…

嵌入式藍橋杯學習拓展 LCD翻轉顯示

通過配置SS和GS兩個標志位&#xff0c;實現掃描方向的切換。 將lcd.c的REG_932X_Init函數進行部分修改。 將LCD_WriteReg(R1, 0x0000);修改為LCD_WriteReg(R1,0x0100); 將LCD_WriteReg(R96, 0x2700); 修改為LCD_WriteReg(R96, 0xA700); void REG_932X_Init1(void) {LCD_Wr…

小程序 —— Day1

組件 — view和scroll-view view 類似于HTML中的div&#xff0c;是一個塊級元素 案例&#xff1a;通過view組件實現頁面的基礎布局 scroll-view 可滾動的視圖區域&#xff0c;用來實現滾動列表效果 案例&#xff1a;實現縱向滾動效果 scroll-x屬性&#xff1a;允許橫向滾動…

git pull error: cannot lock ref

Git: cannot lock ref ‘refs/remotes/origin/feature/xxx’: refs/remotes/origin/feature/xxx/car’ exists; cannot create refs/remotes/origin/feature/xxx git remote prune origin重新整理服務端和本地的關聯關系即可

pubmed關鍵詞搜索技能1:待更新

1&#xff0c;白話變為領域內學術詞&#xff1a; 例如&#xff0c;我想要做蛋白質糖基化修飾以功能&#xff0c;這個領域課題&#xff0c;則 第一性原理&#xff0c;首先是拆分詞匯&#xff1a;糖基化&#xff08;一般比蛋白質、修飾、功能要在title中更常見&#xff0c;或者是…

iPhone手機清理軟件:相冊清理大師推薦

隨著智能手機成為我們日常生活的必需品&#xff0c;手機中的數據日益膨脹&#xff0c;尤其是照片和視頻這類容易積累的文件。對于iPhone用戶來說&#xff0c;管理這些文件&#xff0c;特別是清理相冊變得尤為重要。本文將介紹一款備受推崇的iPhone手機清理軟件——CleanMyPhone…

SpringBoot 開源停車場管理收費系統

一、下載項目文件 下載源碼項目文件口令&#xff1a; 【前端小程序地址】(3.0)&#xff1a;伏脂火器白澤知洞座/~6f8d356LNL~:/【后臺管理地址】(3.0)&#xff1a;伏脂火器仇恨篆洞座/~0f4a356Ks2~:/【崗亭端地址】(3.0)&#xff1a;動作火器智匯堂多好/~dd69356K6r~:/復制口令…

網絡原理之 TCP 協議

目錄 1. TCP 協議格式 2. TCP 原理 (1) 確認應答 (2) 超時重傳 (3) 連接管理 a) 三次握手 b) 四次揮手 (4) 滑動窗口 (5) 流量控制 (6) 擁塞控制 (7) 延時應答 (8) 捎帶應答 3. TCP 特性 4. 異常情況的處理 1) 進程崩潰 2) 主機關機 (正常流程) 3) 主機掉電 (…

STM32使用RCC(Reset Clock Contorl,復位時鐘控制器)配置時鐘以及時鐘樹

RCC主要作用 設置系統時鐘SYSCLK&#xff08;System Clock&#xff09;頻率&#xff1b;設置AHB、APB2、APB1以及各個外設分頻因子&#xff0c;從而設置HCLK、PCLK2、PCLK1以及各個外設的時鐘頻率&#xff1b;控制AHB、APB2、APB1這三條總線時鐘以及每個外設的時鐘開啟&#xf…

安防視頻監控平臺Liveweb視頻匯聚管理系統管理方案

智慧安防監控Liveweb視頻管理平臺能在復雜的網絡環境中&#xff0c;將前端設備統一集中接入與匯聚管理。國標GB28181協議視頻監控/視頻匯聚Liveweb平臺可以提供實時遠程視頻監控、視頻錄像、錄像回放與存儲、告警、語音對講、云臺控制、平臺級聯、磁盤陣列存儲、視頻集中存儲、…