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

结果

相关推荐
TracyCoder1233 分钟前
LeetCode Hot100(51/100)——155. 最小栈
数据结构·算法·leetcode
wu_asia8 分钟前
每日一练叁
算法
dalong109 分钟前
A24:圈住小猫游戏
笔记·算法·游戏·aardio
Y.O.U..13 分钟前
力扣刷题-86.分隔链表
算法·leetcode·链表
Elastic 中国社区官方博客13 分钟前
从向量到关键词:在 LangChain 中的 Elasticsearch 混合搜索
大数据·开发语言·数据库·elasticsearch·搜索引擎·ai·langchain
学编程的闹钟14 分钟前
C语言GetLastError函数
c语言·开发语言·学习
liu****18 分钟前
4.镜像仓库详解
c++·docker·云原生·容器·kubernetes·镜像\
梵刹古音18 分钟前
【C++】多态
开发语言·c++
智算菩萨27 分钟前
上下文学习的贝叶斯推断视角:隐式梯度下降还是隐式贝叶斯?
人工智能·算法
hello 早上好30 分钟前
07_JVM 双亲委派机制
开发语言·jvm