CF1955C Inhabitant of the Deep Sea 題解

題目

模擬

首先想到模擬。
但是看到數據范圍,模擬不了。

#include<bits/stdc++.h>
#include<cstring>
#include<queue>
#include<set>
#include<stack>
#include<vector>
#include<map>
#define int long long
#define lhs printf("\n");
using namespace std;
const int N=1e5+10;
const int M=2024;
const int inf=0x3f3f3f3f;
int t;
int k,n;
int a[N];
int s,e;
int num;
int ans;
int sum1[N],sum2[N];
signed main()
{scanf("%lld",&t);while(t--){scanf("%lld%lld",&n,&k);for(int i=1;i<=n;i++)scanf("%lld",&a[i]);for(int i=1;i<=n;i++){sum1[i]=sum1[i-1]+a[i];}num=ans=0;s=1;e=n;while(num<k and s<=e){a[s]--;num++;if(a[s]<=0){s++;ans++;}if(s>e)break;if(num>=k){ break;}a[e]--;num++;	if(a[e]<=0){e--;ans++; }}printf("%lld\n",ans);}return 0;
}

會TLE

思路

首先模擬的復雜度是o(k)的
k巨大,那么我們模擬不了。
就要想o(n)的解決方法
因為海妖是前面打一下,后面打一下。
所以我們可以把擊打次數分成兩份,前面一份,后面一份。
注意:當k為偶數時,前后數量相通,否則前面一份比后面一份多1。

做法

用前綴和與后綴和數組。
分別尋找滿足小于等于當前方向的那一份之中最大的位置。
找出兩個坐標算出答案。

代碼

#include<bits/stdc++.h>
#include<cstring>
#include<queue>
#include<set>
#include<stack>
#include<vector>
#include<map>
#define int long long
#define lhs printf("\n");
using namespace std;
const int N=3e5+10;
const int M=2024;
const int inf=0x3f3f3f3f;
int t;
int k,n;
int a[N];
int s,e;
int num;
int ans;
int sum1[N],sum2[N];
int sum;
int flag1;
int flag2;
int h;
signed main()
{scanf("%lld",&t);while(t--){memset(sum1,0,sizeof sum1);memset(sum2,0,sizeof sum2);sum=ans=0;scanf("%lld%lld",&n,&k);for(int i=1;i<=n;i++)scanf("%lld",&a[i]),sum+=a[i];if(k>=sum){printf("%lld\n",n);continue;}for(int i=1;i<=n;i++){sum1[i]=sum1[i-1]+a[i];}for(int i=n;i>=1;i--){sum2[i]=sum2[i+1]+a[i];}h=k/2;flag1=0;flag2=n+1;for(int i=1;i<=n;i++){if(sum2[i]<=h){flag2=i;break;}}if(k%2!=0)h++;for(int i=n;i>=1;i--){if(sum1[i]<=h){flag1=i;break;}}printf("%lld\n",flag1+n-flag2+1);}return 0;
}

AC記錄

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

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

相關文章

如何在 Linux 中高亮顯示日志關鍵字

在 Linux 系統中&#xff0c;實時查看日志文件通常使用 tailf 命令&#xff0c;但 tailf 本身并不支持高亮顯示關鍵字功能。通過結合 grep、sed 等工具&#xff0c;我們可以實現日志關鍵字高亮。本文將介紹幾種高效的方法來實現這一目標。 方法一&#xff1a;使用 grep --color…

人機交互中有許多不滿足緊致性條件的地方

緊致性條件通常用于描述拓撲空間的性質。一個拓撲空間被稱為緊致的&#xff0c;如果它的任意開覆蓋都有有限子覆蓋。換句話說&#xff0c;對于任何開覆蓋&#xff0c;都可以從中選取有限個開集&#xff0c;它們的并仍然覆蓋整個空間。 滿足緊致性條件的方法通常包括以下幾種&am…

7月8日 四道經典單鏈表oj題

大家好呀&#xff0c;本博客目的在于記錄暑假學習打卡&#xff0c;后續會整理成一個專欄&#xff0c;主要打算在暑假學習完數據結構&#xff0c;因此會發一些相關的數據結構實現的博客和一些刷的題&#xff0c;個人學習使用&#xff0c;也希望大家多多支持&#xff0c;有不足之…

CSS--表格自適應寬度并設置最小寬度

原文網址&#xff1a;CSS--表格自適應寬度并設置最小寬度_IT利刃出鞘的博客、-CSDN博客 簡介 本文介紹怎樣讓HTML的表格自適應寬度。 Java技術星球&#xff1a;way2j.com 問題描述 默認樣式下&#xff0c;表格會出現某一列很窄的情況&#xff1a; 代碼&#xff1a; <h…

Redission 解鎖異常:attempt to unlock lock, not locked by current thread by node id

標題&#xff1a;解鎖異常&#xff1a;Redission中的"attempt to unlock lock, not locked by current thread by node id"問題分析與解決方案 在分布式系統中&#xff0c;鎖是常用的同步機制&#xff0c;用于保護共享資源&#xff0c;避免并發沖突。Redission是一個…

java-多線程 2

### 7. 線程池 線程池是管理和復用線程的機制&#xff0c;可以避免頻繁創建和銷毀線程的開銷。Java 提供了 Executor 框架來管理線程池。 #### 7.1 使用 Executors 工廠類 Executors 工廠類提供了一些靜態方法&#xff0c;用于創建常見類型的線程池。 java import java.uti…

[240708] 中國 AI 企業在世界人工智能大會上展現韌性與創新

目錄 中國 AI 企業在世界人工智能大會上展現韌性與創新 中國 AI 企業在世界人工智能大會上展現韌性與創新 中國科技公司在本周上海舉行的世界人工智能大會上展現出強大的韌性和創新能力。超過150 種 AI 相關產品和解決方案在大會上展出&#xff0c;包括商湯科技、華為、科大訊…

電機工廠MES系統-提升生產效率與質量的關鍵

本文將詳細介紹萬界星空科技電機行業MES系統的特隨著電機行業的快速發展&#xff0c;生產管理的復雜性和精細度日益提高。為了應對這一挑戰&#xff0c;萬界星空科技MES&#xff08;制造執行系統&#xff09;解決方案&#xff0c;為電機行業帶來了前所未有的生產管理變革。點、…

Elasticsearch 分析器(Analyzer)的作用和配置

在Elasticsearch中&#xff0c;分析器&#xff08;Analyzer&#xff09;是文本處理的核心組件&#xff0c;它負責將輸入的文本轉換為可用于搜索和索引的詞項&#xff08;tokens&#xff09;。這一過程涉及多個步驟&#xff0c;包括字符過濾、分詞和標記過濾&#xff0c;共同決定…

js替換對象內部的對象名稱或屬性名稱-(第二篇)遞歸

1.代碼示例&#xff1a; function replaceKey(obj, oldKey, newKey) {// 如果不是對象或者oldKey不存在&#xff0c;直接返回原對象if (typeof obj ! object || !obj || !(oldKey in obj)) return obj;// 如果是數組&#xff0c;遍歷數組每個元素if (Array.isArray(obj)) {obj…

laravel設計模式詳解

目錄 創造模式 一. 工廠方法模式 1. Eloquent ORM 模型工廠 2. 表單請求工廠 3. 服務容器中的工廠方法 二. 抽象工廠模式 1. 配置文件 2. 服務提供者 3. 門面&#xff08;Facades&#xff09; 4. 多環境配置 5. 依賴注入容器 三.原型模式 1. 配置對象的復制 2. 請…

MyBatis的底層機制

手寫MyBatis底層機制 讀取配置文件&#xff0c;得到數據庫連接 思路 引入必要的依賴需要寫一個自己的config.xml文件&#xff0c;在里面配置一些信息&#xff0c;driver&#xff0c;url &#xff0c;password&#xff0c;username需要編寫Configuration類&#xff0c;對 自己…

aosp 單獨grep某種類型文件,加快grep速度。

1、問題 source build/envsetup.sh lunch xxx 后可以 mgrep 可以單獨搜索makefile文件 cgrep 可以單獨搜索c/c文件 jgrep 可以單獨搜索java文件 具體可以查看build/envsetup.sh cat build/envsetup.sh function jgrep() {find . -name .repo -prune -o -name .git -prune -o …

我“硬剛”mmkv開源庫對于版本號的定義贏啦!

我“硬剛”mmkv開源庫勝利啦&#xff01; 前情是這個帖子https://blog.csdn.net/jzlhll123/article/details/139917169 之前項目中將mmkv1.3.4升級到1.3.5或者1.3.6&#xff0c;就從firebase后臺上看到crash。 java.lang.UnsatisfiedLinkError: dlopen failed: library “libmm…

C#面:闡述什么是依賴注入?

依賴注入&#xff08;Dependency Injection&#xff0c;簡稱DI&#xff09;是一種設計模式&#xff0c;用于解耦組件之間的依賴關系。在傳統的編程模式中&#xff0c;一個對象通常會直接創建和管理它所依賴的其他對象。而在依賴注入中&#xff0c;對象不再負責創建和管理它所依…

申請EV代碼簽名證書費用是多少?

代碼簽名證書是確保軟件安全性和可信度的關鍵工具&#xff0c;在軟件開發領域扮演著至關重要的角色。EV代碼簽名證書&#xff0c;即擴展驗證代碼簽名證書&#xff0c;以其最高級別的安全性和信任度&#xff0c;成為大型企業或對安全性要求較高的軟件的首選。本文旨在深入探討EV…

2024最新版若依-RuoYi-Vue3-PostgreSQL前后端分離項目部署手冊教程

項目簡介: RuoYi-Vue3-PostgreSQL 是一個基于 RuoYi-Vue3 框架并集成 PostgreSQL 數據庫的項目。該項目提供了一套高效的前后端分離的開發解決方案&#xff0c;適用于中小型企業快速構建現代化的企業級應用。此項目結合了 RuoYi-Vue-Postgresql 和 RuoYi-Vue3 的優點&#xff0…

07.C2W2.Part-of-Speech (POS) Tagging and Hidden Markov Models

往期文章請點這里 目錄 OverviewPart of Speech TaggingMarkov ChainsMarkov Chains and POS TagsPOS tags as StatesTransition probabilitiesThe transition matrixInitial probabilities Hidden Markov ModelsEmission probabilitiesSummary Calculating ProbabilitiesTran…

全志A527 T527 設置左右分屏修改為單屏幕,應用分屏改為單屏

1.前言 android13中,A527的系統設置變成,左邊是一級菜單,右側是二級菜單, 這樣跟我們以前android7/8/9的布局是不一樣的,我們需要將它修改為一級菜單,點進去才是二級菜單這種。 效果如下 2.系統設置實現分析 它這里使用的是google新出的embedding activity, 相關的知…