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

结果

相关推荐
敬往事一杯酒哈10 小时前
四元数法基础
算法
有味道的男人10 小时前
京东关键词搜索商品列表的Python爬虫实战
开发语言·爬虫·python
云栖梦泽10 小时前
鸿蒙企业级应用安全开发实战:从数据加密到合规防护
开发语言·鸿蒙系统
情缘晓梦.10 小时前
C语言结构体
c语言·开发语言
leiming610 小时前
c++ 内建函数对象
开发语言·c++·算法
橘颂TA10 小时前
【剑斩OFFER】算法的暴力美学——存在重复元素
数据结构·c++·算法·力扣·散列表·结构与算法
2301_8072886310 小时前
MPRPC项目(第十天,日志功能实现)
开发语言·c++
YJlio10 小时前
PsPing 学习笔记(14.10):常见错误与排错思路——从“不可达”到“端口拒绝”
开发语言·笔记·python·学习·django·pdf·pygame
王老师青少年编程10 小时前
2025年12月GESP(C++五级): 相等序列
c++·算法·gesp·csp·五级·信奥赛·相等序列
报错小能手10 小时前
线程池学习(三) 实现固定线程池(fixed_pthreadpoll)
开发语言·windows·学习