1200*C. Make It Good(二分 || 贪心)

Make It Good - 洛谷

Problem - 1385C - Codeforces

思路一:

二分答案,每次check从mid+1开始,判断能否形成要求的序列。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N=2e5+5;
int t,n,a[N];
bool check(int x){
	int p=0,i=x+1,j=n;
	while(i<=j){ 
		if(a[i]<=a[j]){
			if(a[i]>=p) p=a[i];
			else return false;
			i++;
		}
		else{
			if(a[j]>=p) p=a[j];
			else return false;
			j--;
		}
	}
	return true;
} 
signed main(){
	scanf("%lld",&t);
	while(t--){
		scanf("%lld",&n);
		for(int i=1;i<=n;i++) scanf("%lld",&a[i]);
		int l=0,r=n-1;
		while(l<r){
			int mid=l+r>>1;
			if(check(mid)) r=mid;
			else l=mid+1;
		}
		printf("%lld\n",l);
	}
	return 0;
}

思路二:

我们可以将数据按照大小比喻成一个"山峰",如下图。

左侧则符合题意,右侧则只有右半边的"山峰"符合题意。所以我们从右侧模拟"上山"找到第一个山峰,然后"下山"直到无法"下山"为止即为答案。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N=2e5+5;
int t,n,a[N];
signed main(){
	scanf("%lld",&t);
	while(t--){
		scanf("%lld",&n);
		for(int i=1;i<=n;i++) scanf("%lld",&a[i]);
		int p=n;
		while(a[p-1]>=a[p]&&p>1) p--; 
		while(a[p-1]<=a[p]&&p>1) p--;
		printf("%lld\n",p-1);
	}
	return 0;
}
相关推荐
moonlifesudo5 分钟前
半开区间和开区间的两个二分模版
算法
moonlifesudo9 分钟前
300:最长递增子序列
算法
CoovallyAIHub5 小时前
港大&字节重磅发布DanceGRPO:突破视觉生成RLHF瓶颈,多项任务性能提升超180%!
深度学习·算法·计算机视觉
CoovallyAIHub6 小时前
英伟达ViPE重磅发布!解决3D感知难题,SLAM+深度学习完美融合(附带数据集下载地址)
深度学习·算法·计算机视觉
聚客AI1 天前
🙋‍♀️Transformer训练与推理全流程:从输入处理到输出生成
人工智能·算法·llm
大怪v1 天前
前端:人工智能?我也会啊!来个花活,😎😎😎“自动驾驶”整起!
前端·javascript·算法
惯导马工1 天前
【论文导读】ORB-SLAM3:An Accurate Open-Source Library for Visual, Visual-Inertial and
深度学习·算法
骑自行车的码农1 天前
【React用到的一些算法】游标和栈
算法·react.js
博笙困了1 天前
AcWing学习——双指针算法
c++·算法
moonlifesudo1 天前
322:零钱兑换(三种方法)
算法