1、P1428小鱼比可爱
# 小鱼比可爱
## 题目描述
人比人,气死人;鱼比鱼,难死鱼。小鱼最近参加了一个“比可爱”比赛,比的是每只鱼的可爱程度。参赛的鱼被从左到右排成一排,头都朝向左边,然后每只鱼会得到一个整数数值,表示这只鱼的可爱程度,很显然整数越大,表示这只鱼越可爱,而且任意两只鱼的可爱程度**可能一样**。由于所有的鱼头都朝向左边,所以每只鱼只能看见在它左边的鱼的可爱程度,它们心里都在计算,在自己的眼力范围内有多少只鱼不如自己可爱呢。请你帮这些可爱但是鱼脑不够用的小鱼们计算一下。
## 输入格式
第一行输入一个正整数 $n$,表示鱼的数目。
第二行内输入 $n$ 个正整数,用空格间隔,依次表示从左到右每只小鱼的可爱程度 $a_i$。
## 输出格式
一行,输出 $n$ 个整数,用空格间隔,依次表示每只小鱼眼中有多少只鱼不如自己可爱。
## 样例 #1
### 样例输入 #1
```
6
4 3 0 5 1 2
```
### 样例输出 #1
```
0 0 0 3 1 2
```
## 提示
对于 $100\%$ 的数据,$1 \leq n\leq 100$,$0 \leq a_i \leq 10$。
题解
n=int(input())
a=list(map(int,input().split()))
for i in range(n):
cnt=0
for j in range(i):
if a[j]<a[i]:
cnt+=1
print(cnt,end=' ')
注:列表输入:a=list(map(int,input().split()))
2、P1047校门口的树
# [NOIP2005 普及组] 校门外的树
## 题目描述
某校大门外长度为 $l$ 的马路上有一排树,每两棵相邻的树之间的间隔都是 $1$ 米。我们可以把马路看成一个数轴,马路的一端在数轴 $0$ 的位置,另一端在 $l$ 的位置;数轴上的每个整数点,即 $0,1,2,\dots,l$,都种有一棵树。
由于马路上有一些区域要用来建地铁。这些区域用它们在数轴上的起始点和终止点表示。已知任一区域的起始点和终止点的坐标都是整数,区域之间可能有重合的部分。现在要把这些区域中的树(包括区域端点处的两棵树)移走。你的任务是计算将这些树都移走后,马路上还有多少棵树。
## 输入格式
第一行有两个整数,分别表示马路的长度 $l$ 和区域的数目 $m$。
接下来 $m$ 行,每行两个整数 $u, v$,表示一个区域的起始点和终止点的坐标。
## 输出格式
输出一行一个整数,表示将这些树都移走后,马路上剩余的树木数量。
## 样例 #1
### 样例输入 #1
```
500 3
150 300
100 200
470 471
```
### 样例输出 #1
```
298
```
## 提示
**【数据范围】**
- 对于 $20\%$ 的数据,保证区域之间没有重合的部分。
- 对于 $100\%$ 的数据,保证 $1 \leq l \leq 10^4$,$1 \leq m \leq 100$,$0 \leq u \leq v \leq l$。
**【题目来源】**
NOIP 2005 普及组第二题
题解
思路:一道经典的数组题目。先种树,再砍树,计算最后剩下的树
l,m=map(int,input().split())
book=[1 for i in range(10086)]
cnt=0
for i in range(l+1): #种树
book.append(1)
for _ in range(m):
u,v=map(int,input().split())
for i in range(u,v+1):
book[i]=0 #砍树
for i in range(l+1):
if book[i]==1:
cnt+=1
print(cnt)
注:一维列表的生成要比要求的数据长度大 book=[1 for i in range(10086)]