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

结果

相关推荐
lly2024061 分钟前
C++ 数组
开发语言
csbysj202014 分钟前
C 强制类型转换
开发语言
m0_6265352016 分钟前
代码分析
开发语言·c#
q***37517 分钟前
QoS质量配置
开发语言·智能路由器·php
__BMGT()22 分钟前
参考文章资源记录
开发语言·c++·qt
一晌小贪欢25 分钟前
【Python办公】用 Selenium 自动化网页批量录入
开发语言·python·selenium·自动化·python3·python学习·网页自动化
ouliten28 分钟前
C++笔记:std::string_view
开发语言·c++·笔记
玫瑰花店39 分钟前
万字C++中锁机制和内存序详解
开发语言·c++·算法
D_evil__43 分钟前
[C++高频精进] 文件IO:文件流
c++
西幻凌云1 小时前
认识STL序列式容器——List
开发语言·c++·stl·list·序列式容器