AKSZ-枚举算法
2024-03-23 18:45:32
发布于:广东
进制转换
十转二
整数部分:除二取余,逆序排列
小数部分:乘二取整,顺序排列
十转八
整数部分:除八取余,逆序排列
小数部分:乘八取整,顺序排列
十转十六
整数部分:除十六取余,逆序排列
小数部分:乘十六取整,顺序排列
十转n
整数部分:除n取余,逆序排列
小数部分:乘n取整,顺序排列
枚举算法
三要素
1、枚举对象
2、枚举范围
3、判定条件
函数
#include<algorithm>
next_permutation(a,a+n)
测试运行时间
#include<time.h>
using namespace std;
int main(){
clock_t start end;
start=clock();
\\程序
end=clock();
printf("%.2lf MS",double(end - start) / CLOCKS_PER_SEC * 1000)
}
枚举子集
#include<iostream>
using namespace std;
int n;
int a[10];
void solve(int x){
for(int i=0;i<n;i++){
if( (1<<i) & x){
cout<<a[x]<<" ";
}
}
puts("");
}
int main(){
cin>>n;
for(int i=0;i<n;i++)cin>>a[i];
for(int i=0;i<=(1<<n)-1;i++){
solve(i);
}
}
埃氏筛法
时间复杂度:
#include<iostream>
using namespace std;
const int maxn=30;
int n=1000000;
int p[N];
void init(){
for(int i=2;i<=n;i++){
if(!p[i]){
for(int j=2*i;j<=n;j+=i){
p[j]=1;
}
}
}
}
这里空空如也
有帮助,赞一个