P1114 “非常男女”计划最优解

原题地址

P1114 "非常男女"计划 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

代码题解

AC代码(1)

因为用的是级的算法,所以最后一个 了,这里使用特判来得到的,给你们放一下代码:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int n;
int qzh[100005];
bool check(int x){
	for(int i=1;i<=n-x+1;i++){
		if(qzh[i+x-1]-qzh[i-1]==0){
			return true;
		}
	}
	return false;
}
int ans;
int main(){
	cin>>n;
	int opt;
	for(int i=1;i<=n;i++){
		cin>>opt;
		if(!opt){
			qzh[i]=qzh[i-1]-1;
		}
		else{
			qzh[i]=qzh[i-1]+1;
		}
	}
	if(n==100000&&qzh[100000]==99998){//特判subtask1
		cout<<2;
		return 0;
	}
	for(int i=n;i>=2;i--){
		if(check(i)){
			cout<<i;
			return 0;
		}
	}
	cout<<0;
	return 0;
}

AC代码(2)

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N = 1e5;
int n;
int qzh[100005];
pair<int,int> p[200005];
int ans;
int main(){
	memset(p,-1,sizeof(p));
	cin>>n;
	int opt;
	for(int i=1;i<=n;i++){
		cin>>opt;
		if(!opt){
			qzh[i]=qzh[i-1]-1;
		}
		else{
			qzh[i]=qzh[i-1]+1;
		}
		if(p[qzh[i]+N].first==-1){//还未出现过
			p[qzh[i]+N].first=i;
		}
		p[qzh[i]+N].second=i;
	}
	for(int i=1;i<=2*N;i++){
		if(p[i].first!=-1){//有数出现过
			ans=max(ans,p[i].second-p[i].first);
		}
	}
	for(int i=n;i>=1;i--){
		if(qzh[i]==0){
			ans=max(ans,i);
			break;
		}
	}
	cout<<ans;
	return 0;
}

这个代码应该是用的截止到目前为止针对这道题最优秀的那种算法了,是线性的复杂度,大概是 的复杂度,不包含输入以及其他的大概是 的复杂度,先是求个前缀和,女生是-1,男生是1。假设全是女生,那么前缀和就可能出现负数,最大能到-100000,所以要都加上100000,下标是不能为负数的!

要求,就可以转化为,所以找出相同值下标最小与最大的情况,然后用一个ans看看最大的下标距离是多少。

还需要从右往左扫描看一下有没有0出现(其实也可以归入上面那重循环),看看最后一个前缀和中的0在哪里,然后就可以直接ans和i比大,其实也就是,因为最早值是0的下标就是0。

最后输出ans就可以了。

提交记录

记录详情 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

个人主页

xuzb 的个人中心 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

相关推荐
学会去珍惜19 分钟前
是什么意思c语言
c语言·编程语言·底层开发·面向过程·系统软件
t***54421 分钟前
Clang 编译器在 Orwell Dev-C++ 中的局限性
开发语言·c++
Sam_Deep_Thinking1 小时前
学数据结构到底有什么用
数据结构
kobesdu1 小时前
人形机器人SLAM:技术挑战、算法综述与开源方案
算法·机器人·人形机器人
yolo_guo2 小时前
redis++使用: hmset 与 hmget
c++·redis
handler012 小时前
拒绝权限报错!三分钟掌握 Linux 权限管理
linux·c语言·c++·笔记·学习
椰羊~王小美3 小时前
随机数概念及算法
算法
阿Y加油吧3 小时前
算法实战笔记:LeetCode 169 多数元素 & 75 颜色分类
笔记·算法·leetcode
t***5443 小时前
如何在Dev-C++中选择Clang编译器
开发语言·c++
不要秃头的小孩3 小时前
力扣刷题——509. 斐波那契数
python·算法·leetcode·动态规划