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

结果

相关推荐
爱编程的鱼2 分钟前
C# 数据类型||C# 类型转换
java·算法·c#
一键三联啊2 分钟前
ArrayList的subList的数据仍是集合
java·开发语言
@hdd2 分钟前
C++ | STL之list详解:双向链表的灵活操作与高效实践
c++·list
Haohao+++3 分钟前
leetcode面试经典算法题——2
算法·leetcode·面试
蓝白咖啡6 分钟前
LinkedList<Integer> 常用方法通俗讲解
数据结构·算法·jave
purrrew9 分钟前
【数据结构_8】栈和队列
java·开发语言·数据结构
凤年徐20 分钟前
【C/C++】深入理解指针(二)
c语言·开发语言·c++·经验分享·笔记·指针
Hello-FPGA27 分钟前
QT 初体验
开发语言·qt
coder777741 分钟前
js逆向分享
javascript·爬虫·python·算法·安全
Cao1234567893211 小时前
扫雷-C语言版
c语言·开发语言