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

结果

相关推荐
阿杰同学几秒前
Java 设计模式 面试题及答案整理,最新面试题
java·开发语言·设计模式
这样の我几秒前
java 模拟chrome指纹 处理tls extension顺序
java·开发语言·chrome
yong99902 分钟前
基于MATLAB的雷达压制干扰仿真
开发语言·matlab
汉克老师2 分钟前
2025年海淀区中小学信息学竞赛复赛(小学组试题第六题 蜂窝网络 (net))
c++·贪心算法·北京海淀中小学信息学竞赛·lower_bound
xiaoye-duck4 分钟前
C++入门基础指南:命名空间namespace
c++
Genevieve_xiao5 分钟前
【数据结构与算法】【xjtuse】面向考纲学习(下)
java·数据结构·学习·算法
4311媒体网7 分钟前
php和c++哪个更好学?C++难学吗?
java·c++·php
修炼地7 分钟前
代码随想录算法训练营第二十七天 | 56. 合并区间、738.单调递增的数字、968.监控二叉树
c++·算法
仰泳的熊猫9 分钟前
1031 Hello World for U
数据结构·c++·算法·pat考试
catchadmin13 分钟前
现代高效 PHP 开发的最佳实践
开发语言·后端·php