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

结果

相关推荐
qq_411262422 分钟前
短时间串口发送网络端怎么接收不到
开发语言·php
静谧空间4 分钟前
java登录验证码CaptchaConfig
java·开发语言
Imxyk8 分钟前
力扣:632. 最小区间(贪心)
java·数据结构·算法
小高Baby@8 分钟前
session、cookie、Jwt-token
开发语言·后端·golang
maplewen.11 分钟前
C++11 std::mutex
开发语言·c++
jiaguangqingpanda12 分钟前
Day37-20260205
java·开发语言
Mr_Xuhhh13 分钟前
递归和迭代的区别(C/C++实现)
算法
历程里程碑14 分钟前
21:重谈重定义理解一切皆“文件“及缓存区
linux·c语言·开发语言·数据结构·c++·算法·缓存
2501_9011478317 分钟前
PyTorch DDP官方文档学习笔记(核心干货版)
pytorch·笔记·学习·算法·面试
wxin_VXbishe17 分钟前
springboot旅游信息管理系统-计算机毕业设计源码21675
java·c++·spring boot·python·spring·django·php