solution.md 1.5 KB
Newer Older
每日一练社区's avatar
每日一练社区 已提交
1
# 抽签
F
fix bug  
feilong 已提交
2

每日一练社区's avatar
每日一练社区 已提交
3 4 5 6 7 8 9 10 11 12
X星球要派出一个5人组成的观察团前往W星。
其中:
A国最多可以派出4人。
B国最多可以派出2人。
C国最多可以派出2人。
....

那么最终派往W星的观察团会有多少种国别的不同组合呢?

#### 输入格式
F
fix bug  
feilong 已提交
13

每日一练社区's avatar
每日一练社区 已提交
14 15
第一行N,以下N行代表N个国家最多可派出人数Ai。
#### 输出格式
F
fix bug  
feilong 已提交
16

每日一练社区's avatar
每日一练社区 已提交
17 18
最多多少种派法ANS,ANS为一个整数。
#### 输出规模
F
fix bug  
feilong 已提交
19

每日一练社区's avatar
每日一练社区 已提交
20 21 22 23 24
```
1<N<10000
1<AI<10000
```
#### 示例输入
F
fix bug  
feilong 已提交
25

每日一练社区's avatar
每日一练社区 已提交
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41
```
6
4
2
2
1
1
3
```
示例输出
```
101
```


## aop
F
fix bug  
feilong 已提交
42

每日一练社区's avatar
每日一练社区 已提交
43
### before
F
fix bug  
feilong 已提交
44

每日一练社区's avatar
每日一练社区 已提交
45 46 47 48 49 50
```cpp
#include <iostream>
using namespace std;
int a[10000], N, i, ans = 0;
```
### after
F
fix bug  
feilong 已提交
51

每日一练社区's avatar
每日一练社区 已提交
52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
```cpp
int main()
{
	
	cin >> N;
	for (i = 0; i < N; i++)
	{
		cin >> a[i];
	}
	findAns(a, 0, 0);

	cout << ans << endl;
	return 0;
}
```

## 答案
F
fix bug  
feilong 已提交
69

每日一练社区's avatar
每日一练社区 已提交
70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
```cpp
void findAns(int a[], int start, int An) 
{
	if (start == N) 
	{
		if (An == 5)
			ans++; 
		return;
	}

	for (i = 0; i <= a[start]; i++) 
	{
		findAns(a, start + 1, An + i); 
	}
}
```
## 选项

F
fix bug  
feilong 已提交
88

每日一练社区's avatar
每日一练社区 已提交
89
### A
F
fix bug  
feilong 已提交
90

每日一练社区's avatar
每日一练社区 已提交
91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
```cpp
void findAns(int a[], int start, int An) 
{
	if (start == N) 
	{
		if (An == 5)
			ans++; 
		return;
	}

	for (i = 0; i <= a[start]; i++) 
	{
		findAns(a, start + 1, An); 
	}
}
```

### B
F
fix bug  
feilong 已提交
109

每日一练社区's avatar
每日一练社区 已提交
110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127
```cpp
void findAns(int a[], int start, int An) 
{
	if (start == N) 
	{
		if (An == 5)
			ans++; 
		return;
	}

	for (i = 0; i <= a[start]; i++) 
	{
		findAns(a, start, An + i); 
	}
}
```

### C
F
fix bug  
feilong 已提交
128

每日一练社区's avatar
每日一练社区 已提交
129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144
```cpp
void findAns(int a[], int start, int An) 
{
	if (start == N) 
	{
		if (An == 5)
			ans++; 
		return;
	}

	for (i = 0; i <= a[start]; i++) 
	{
		findAns(a, start, An + 1); 
	}
}
```