码迷,mamicode.com
首页 > 其他好文 > 详细

[bzoj1081]超级格雷码

时间:2019-11-07 13:22:28      阅读:73      评论:0      收藏:0      [点我收藏+]

标签:hide   lse   lap   超级   操作   color   c++   code   opened   

手动模拟一组样例,可以理解大致应该如何操作
具体实现中,记录每一位当前应该+1还是-1,然后操作最低的位并将后面的+1和-1全部取反即可

技术图片
 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 int n,b,a[105],flag[105];
 4 void write(){
 5     for(int i=1;i<=n;i++)
 6         if (a[i]<10)printf("%d",a[i]);
 7         else printf("%c",a[i]-10+A);
 8     printf("\n");
 9 }
10 int main(){
11     scanf("%d%d",&n,&b);
12     for(int i=1;i<=n;i++)flag[i]=1;
13     while (1){
14         write();
15         int i=1;
16         for(;i<=n;i++)
17             if ((0<=flag[i]+a[i])&&(flag[i]+a[i]<b)){
18                 a[i]+=flag[i];
19                 for(int j=i-1;j;j--)flag[j]*=-1;
20                 break;
21             }
22         if (i>n)break;
23     }
24 }
View Code

 

[bzoj1081]超级格雷码

标签:hide   lse   lap   超级   操作   color   c++   code   opened   

原文地址:https://www.cnblogs.com/PYWBKTDA/p/11811301.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!