枚舉
列出所有可能
聰明的枚舉
/*
* NTUCPC
* 湊平方數
*/
#include <bits/stdc++.h>
using namespace std;
int main() {
int N;
cin >> N;
for(int c=sqrt(N);c>=1;--c){
for(int a=1;a<c*c;++a){
int b=c*c-a;
cout << "[" << a << "," << b << "," << c << "]" << endl;
}
}
}
子集合
/*
* AP325
* P-1-7. 子集合乘積
*/
#include<bits/stdc++.h>
using namespace std;
int n;
int f(int a[],int i,int sum){
if(i>=n){
cout << sum << endl;
return 0;
}
f(a, i + 1, ((sum==0) ? 1 : sum) * a[i]);
f(a, i + 1, sum);
}
int main(){
cin >> n;
int a[n];
int p=10009;
for(int i=0;i<n;i++){
cin >> a[i];
}
f(a,0,0);
}
next_permutatio([ ],[ ]+n)
#include <bits/stdc++.h>
using namespace std;
int a[6][6];
int cnt[6];
int main() {
for (int i = 0; i < 6; i++) {
for (int j = 0; j < 6; j++){
cin >> a[i][j];
}
cin >> cnt[i];
}
int p[6] = {1, 2, 3, 4, 5, 6};
do {
bool ok = true;
for (int i = 0; i < 6; i++) {
int tmp = 0;
for (int j = 0; j < 6; j++) {
if(p[j] == a[i][j]){
tmp++;
}
}
if (tmp != cnt[i]) {
ok = false;
break;
}
}
if (ok) {
for (int i = 0; i < 6; i++) cout << p[i] << " \n"[i == 5];
break;
}
}
while (next_permutation(p, p + 6)); // 所有排列可能 (字典序 小~大)
}
Last updated
Was this helpful?