【CSP CCF记录】数组推导

题目

过程

思路

每次输入一个Bi即可确定一个Ai值,用temp记录1~B[i-1],的最大值分为两种情况:

  1. 当temp不等于Bi时,则说明Bi值之前未出现过,Ai必须等于Bi才能满足Bi是Ai前缀最大的定义。
  2. 当temp等于Bi时,则说明Bi值之前已经出现过,此时Ai最小为0,最大为Bi。

最大值big和最小值small根据不同情况相加。

代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int n;
int B[100010];
int main()
{
	cin>>n;
	int big=0;
	int small=0;
	int temp=0;//当前最大值 
	for(int i=1;i<=n;i++)
	{
		cin>>B[i];
		
		if(temp!=B[i]) 
		{
			big+=B[i];
			temp=B[i];
			small+=temp; 
		}
		else
		{
			big+=temp;
			small+=0;
		}
		
	}
	cout<<big<<endl;
	cout<<small<<endl;
	
}

结果

相关推荐
C_心欲无痕12 小时前
ts - 关于Object、object 和 {} 的解析与区别
开发语言·前端·javascript·typescript
a程序小傲13 小时前
得物Java面试被问:方法句柄(MethodHandle)与反射的性能对比和底层区别
java·开发语言·spring boot·后端·python·面试·职场和发展
sinat_2869451913 小时前
AI Coding LSP
人工智能·算法·prompt·transformer
独自破碎E13 小时前
比较版本号
java·开发语言
星马梦缘13 小时前
算法与数据结构
数据结构·c++·算法·动态规划·克鲁斯卡尔·kahn
zimoyin13 小时前
浅浅了解下0拷贝技术
java·linux·开发语言
AI架构师易筋13 小时前
AIOps 告警归因中的提示工程:从能用到可上生产(4 阶梯)
开发语言·人工智能·llm·aiops·rag
你的冰西瓜13 小时前
C++中的array容器详解
开发语言·c++·stl
2501_9434691513 小时前
【无标题】
数据结构·算法
_codemonster13 小时前
计算机视觉入门到实战系列(八)Harris角点检测算法
python·算法·计算机视觉