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

结果

相关推荐
呼啦啦561几秒前
【C++入门】
c++
softshow1026几秒前
html2canvas + jspdf实现页面导出成pdf
开发语言·javascript·pdf
苦藤新鸡2 分钟前
19.旋转输出矩阵
c++·算法·leetcode·力扣
zsffuture3 分钟前
RKNN 8位量化全解析:算法差异与粒度选择实战指南
算法
玄冥剑尊3 分钟前
贪心算法深化 II
算法·贪心算法
Pluchon3 分钟前
硅基计划4.0 算法 动态规划入门
java·数据结构·算法·动态规划
玄冥剑尊4 分钟前
贪心算法深化 III
算法·贪心算法
Java程序员威哥11 分钟前
Java应用容器化最佳实践:Docker镜像构建+K8s滚动更新(生产级完整模板+避坑指南)
java·开发语言·后端·python·docker·kubernetes·c#
qq_21539789715 分钟前
python环境无网络环境导入依赖
开发语言·python
小范馆17 分钟前
C++ 编译方法对比:分步编译 vs 一步到位
java·开发语言·c++