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

结果

相关推荐
OneT1me2 分钟前
CVE-2026-31431 的C语言版本
c语言·开发语言·安全威胁分析
刀法如飞15 分钟前
Python列表去重:从新手三连到高阶特技,20种解法全收录
python·算法·编程语言
minji...16 分钟前
算法题 动态规划
算法·动态规划
xun-ming28 分钟前
AI时代Java程序员自救手册
java·开发语言·人工智能
张健115640964832 分钟前
C++访问控制与友元
java·开发语言·c++
水蓝烟雨41 分钟前
3337. 字符串转换后的长度 II
算法·leetcode
MegaDataFlowers44 分钟前
SiliconCompiler workflow
算法
_日拱一卒1 小时前
LeetCode:226翻转二叉树
数据结构·算法·leetcode
2zcode1 小时前
基于MATLAB改进最大熵法的大规模新能源并网概率潮流计算
开发语言·matlab
一只幸运猫.1 小时前
JAVA后端面试题
java·开发语言