洛谷【入门4】数组-P1428 小鱼比可爱

## 题目描述

人比人,气死人;鱼比鱼,难死鱼。小鱼最近参加了一个"比可爱"比赛,比的是每只鱼的可爱程度。参赛的鱼被从左到右排成一排,头都朝向左边,然后每只鱼会得到一个整数数值,表示这只鱼的可爱程度,很显然整数越大,表示这只鱼越可爱,而且任意两只鱼的可爱程度**可能一样**。由于所有的鱼头都朝向左边,所以每只鱼只能看见在它左边的鱼的可爱程度,它们心里都在计算,在自己的眼力范围内有多少只鱼不如自己可爱呢。请你帮这些可爱但是鱼脑不够用的小鱼们计算一下。

## 输入格式

第一行输入一个正整数 n,表示鱼的数目。

第二行内输入 n 个正整数,用空格间隔,依次表示从左到右每只小鱼的可爱程度 ai​。

## 输出格式

一行,输出 n 个整数,用空格间隔,依次表示每只小鱼眼中有多少只鱼不如自己可爱。

## 样例 #1

### 样例输入 #1

6

4 3 0 5 1 2

### 样例输出 #1

0 0 0 3 1 2

## 提示

对于 100%的数据,1≤n≤100,0≤ai​≤10。

分析:

简单的数组循环题,定义两个数组,一个来存鱼的可爱值,一个来存多少不如的数量。

先一个循环依次输入,之后两个循环嵌套,第一个循环用来遍历鱼儿,第二用来和前面的鱼依次比较,最后再用循环输出。

注意点,第一个小鱼永远为0,所以比较的过程中是从第二条鱼a[1]开始的,输出的时候也是先输出0,再输出n-1个。

完整代码:

cpp 复制代码
#include <iostream>
using namespace std;
int a[101],b[101],n;
int main(){
	
	cin>>n;
	for(int i=0;i<n;i++)
		cin>>a[i];
	for(int i=1;i<n;i++){
		for(int j=i;j>=0;j--){
			if(a[j]<a[i])
				b[i]++;
		}
	}
	cout<<0<<" ";
	for(int i=1;i<n;i++)
		cout<<b[i]<<" ";
	return 0;
}
相关推荐
busideyang4 分钟前
函数指针类型定义笔记
c语言·笔记·stm32·单片机·算法·嵌入式
Wect5 分钟前
LeetCode 215. 数组中的第K个最大元素:大根堆解法详解
前端·算法·typescript
深邃-16 分钟前
数据结构-双向链表
c语言·开发语言·数据结构·c++·算法·链表·html5
2401_8785302118 分钟前
分布式任务调度系统
开发语言·c++·算法
_深海凉_34 分钟前
LeetCode热题100-两数之和
算法·leetcode·职场和发展
nunca_te_rindas38 分钟前
算法刷体小结汇总(C/C++)20260328
c语言·c++·算法
Sunshine for you41 分钟前
高性能压缩库实现
开发语言·c++·算法
Sunshine for you42 分钟前
C++中的表达式模板
开发语言·c++·算法
qwehjk200843 分钟前
C++中的状态模式
开发语言·c++·算法
Fortune791 小时前
自定义类型转换机制
开发语言·c++·算法