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;
}
相关推荐
❥ღ Komo·2 小时前
K8s1.28.15网络插件Calico全解析
开发语言·php
❥ღ Komo·2 小时前
K8s服务发现与DNS解析全解析
java·开发语言
FuckPatience2 小时前
C# 项目调试的时候进不去断点
开发语言·c#
元亓亓亓2 小时前
考研408--组成原理--day8--汇编指令&不同语句的机器级表示
开发语言·汇编·c#
hnjzsyjyj6 小时前
东方博宜OJ 2190:树的重心 ← 邻接表 or 链式前向星
数据结构·链式前向星·树的重心
yaoh.wang8 小时前
力扣(LeetCode) 13: 罗马数字转整数 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
ChoSeitaku8 小时前
NO15数据结构选择题考点|线性表|栈和队列|串
数据结构
T1ssy8 小时前
布隆过滤器:用概率换空间的奇妙数据结构
算法·哈希算法
醇氧8 小时前
【Windows】优雅启动:解析一个 Java 服务的后台启动脚本
java·开发语言·windows
hetao17338379 小时前
2025-12-12~14 hetao1733837的刷题笔记
数据结构·c++·笔记·算法