【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;
	
}

结果

相关推荐
忡黑梨3 分钟前
eNSP_DHCP配置
c语言·网络·c++·python·算法·网络安全·智能路由器
陈壮实的搬砖日记16 分钟前
白话生成式推荐二:MiniOneRec之RQ-VAE
算法
skywalk816320 分钟前
CodeArts碰到问题:CodeArts 智能体使用失败,显示:会话创建失败,请稍后重试
开发语言·python
陈壮实的搬砖日记30 分钟前
白话生成式推荐二:MiniOneRec之SFT
算法
白露与泡影32 分钟前
从区间锁到行锁:一次高并发写入死锁治理实战
java·开发语言
小短腿的代码世界34 分钟前
VLC-Qt深度解析:Qt应用中的专业视频播放方案
开发语言·qt
丑八怪大丑38 分钟前
Java范型
java·开发语言
加藤不太惠38 分钟前
Nacos简单实用集群创建
java·开发语言·nacos
我能坚持多久40 分钟前
C++的Vector学习:从功能探索到底层实现
开发语言·c++·学习
她说彩礼65万41 分钟前
C语言 动态内存管理
c语言·开发语言·算法