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

结果

相关推荐
蒲小英6 分钟前
算法-贪心算法
算法·贪心算法
Alpha first6 分钟前
C++核心知识点梳理:类型兼容、多继承与虚基类
开发语言·c++
.小小陈.7 分钟前
C++初阶9:list使用攻略
开发语言·c++·学习·list
mit6.8248 分钟前
链式投票|流向贪心
算法
qq_5895681010 分钟前
@NotBlank与@NotEmpty注解无法导入
java·开发语言
君义_noip25 分钟前
洛谷 P4777 【模板】扩展中国剩余定理(EXCRT)
算法·数论·信息学奥赛·csp-s
天赐学c语言26 分钟前
12.14 - 搜索旋转排序数组 && 判断两个结构体是否相等
数据结构·c++·算法·leecode
1024肥宅40 分钟前
JavaScript 性能与优化:数据结构和算法
前端·数据结构·算法
超自然祈祷1 小时前
水声相关公式C++实现
开发语言·c++
kaikaile19951 小时前
MATLAB 灰度图像的二维傅里叶变换
算法·计算机视觉·matlab