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

结果

相关推荐
s砚山s2 分钟前
代码随想录刷题——二叉树篇(十三)
数据结构·算法
落羽凉笙2 分钟前
Python基础(4)| 玩转循环结构:for、while与嵌套循环全解析(附源码)
android·开发语言·python
ytttr8735 分钟前
MATLAB的流体动力学与热传导模拟仿真实现
开发语言·matlab
alphaTao6 分钟前
LeetCode 每日一题 2026/1/5-2026/1/11
算法·leetcode
山上三树8 分钟前
详细介绍 C 语言中的 #define 宏定义
c语言·开发语言·算法
测试游记16 分钟前
基于 FastGPT 的 LangChain.js + RAG 系统实现
开发语言·前端·javascript·langchain·ecmascript
DYS_房东的猫17 分钟前
写出第一个程序
c++
小罗和阿泽20 分钟前
java 【多线程基础 三】
java·开发语言
ulias21220 分钟前
AVL树的实现
开发语言·数据结构·c++·windows
想你依然心痛21 分钟前
从x86到ARM的HPC之旅:鲲鹏开发工具链(编译器+数学库+MPI)上手与实战
java·开发语言·arm开发·鲲鹏·昇腾