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

结果

相关推荐
每天要多喝水5 分钟前
动态规划Day30:买卖股票
算法·动态规划
v_for_van11 分钟前
力扣刷题记录6(无算法背景,纯C语言)
c语言·算法·leetcode
之歆12 分钟前
HA 高可用集群指南
java·开发语言
-To be number.wan14 分钟前
算法学习日记 | 双指针
c++·学习·算法
lsx20240638 分钟前
电子商务网站主机:选择与维护指南
开发语言
样例过了就是过了1 小时前
LeetCode热题100 最大子数组和
数据结构·算法·leetcode
wangluoqi1 小时前
c++ 逆元 小总结
开发语言·c++
BackCatK Chen1 小时前
第十五章 吃透C语言结构与数据形式:struct/union/typedef全解析
c语言·开发语言·数据结构·typedef·结构体·函数指针·联合体
瓦特what?1 小时前
插 入 排 序
开发语言·c++
铸人1 小时前
再论自然数全加和 - 欧拉伽马常数
数学·算法·数论·复数