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)

相关推荐
To_OC9 小时前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安14 小时前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者17 小时前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent
北域码匠20 小时前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
卷无止境1 天前
C++ 的Eigen 库全解析
c++
卷无止境1 天前
现代 C++特性大盘点:一门脱胎换骨的老语言
c++·后端
郝学胜_神的一滴1 天前
CMake 27:缓存变量的特性、语法、类型与实操全解
c++·cmake
kisshyshy1 天前
从递归到迭代,一文吃透二叉树的核心知识与 JavaScript 实现
javascript·算法·代码规范