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

结果

相关推荐
昵称小白3 分钟前
C++ 刷题语法速查
c++·算法
JQLvopkk6 分钟前
C# 工业级数据可视化:用ScottPlot让10万个点流畅显示的实战秘籍
人工智能·算法·机器学习
ch.ju10 分钟前
Java programming(The third edition) Chapter Two——Null return value
java·开发语言
折哥的程序人生 · 物流技术专研29 分钟前
第3篇:为何要配置环境变量?
java·开发语言·后端·面试
Qt程序员32 分钟前
【无标题】
linux·c++·消息队列·共享内存·c/c++·管道·信号量
神仙别闹35 分钟前
基于C# 利用工程活动图 AOE 网设计算法
算法·c#·php
地平线开发者35 分钟前
Linux 性能优化工具
算法·自动驾驶
游乐码35 分钟前
c#迭代器
开发语言·c#
十五年专注C++开发41 分钟前
Qt程序设计涉及到的开发软件
开发语言·c++·qt
海盗123442 分钟前
C# OPC UA客户端开发实战
服务器·开发语言·c#