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)

相关推荐
样例过了就是过了5 分钟前
LeetCode热题100 回文链表
数据结构·算法·leetcode·链表
汉克老师5 分钟前
GESP2023年12月认证C++二级( 第二部分判断题(1-10))
c++·循环结构·分支结构·gesp二级·gesp2级
地平线开发者8 分钟前
【地平线 征程 6 工具链进阶教程】算子优化方案集锦
算法·自动驾驶
多恩Stone22 分钟前
【3D-AICG 系列-14】Trellis 2 的 Texturing Pipeline 保留单层薄壳,而 Textured GLB 会变成双层
人工智能·python·算法·3d·aigc
Solitary-walk26 分钟前
前缀和思想
数据结构·c++·算法
智驱力人工智能28 分钟前
机场鸟类活动智能监测 守护航空安全的精准工程实践 飞鸟检测 机场鸟击预防AI预警系统方案 机场停机坪鸟类干扰实时监测机场航站楼鸟击预警
人工智能·opencv·算法·安全·yolo·目标检测·边缘计算
消失的旧时光-194328 分钟前
拷贝构造 vs 移动构造:从左值引用到右值引用彻底讲透(Student 示例)
c++·拷贝构造·移动构造
量子物理学33 分钟前
三、C#高级进阶语法——特性(Attribute)
java·算法·c#
忍者必须死1 小时前
JDK1.7的HashMap的环形链表
java·数据结构·算法·链表
NEXT061 小时前
数组转树与树转数组
前端·数据结构·面试