• P6183 [USACO10MAR] The Rock Game S


    在奶牛回家休息和娱乐之前,Farmer John 希望它们通过玩游戏获得一些智力上的刺激。游戏板由 nn 个相同的孔组成,这些孔最初都是空的。一头母牛要么用石头盖住一个洞,要么揭开一个先前被盖住的洞。游戏状态的定义是哪些洞被石头覆盖,哪些洞没有覆盖。游戏的目标是让奶牛准确地到达每个可能的游戏状态一次,然后返回到所有洞都没有覆盖的状态。以下是他们其中一次游戏的示例(空的洞用 O 表示,用石头盖住的洞用 X 表示):

    时间洞 1洞 2洞 3描述
    00OOO一开始所有的洞都是空的
    11OOX盖上洞 3
    22XOX盖上洞 1
    33XOO打开洞 3
    44XXO盖上洞 2
    55OXO打开洞 1
    66OXX盖上洞 3
    77XXX盖上洞 1

    现在牛被卡住玩不下去了!他们必须打开一个洞,不管他们打开哪个洞,他们都会到达一个他们已经到达的状态。例如,如果他们从第二个洞中取出岩石,他们将到达他们在时间 22 已经访问过的状态(X O X)。

    下面是一个 3 个孔的有效解决方案:

    时间洞 1洞 2洞 3描述
    00OOO一开始所有的洞都是空的
    11OXO盖上洞 2
    22OXX盖上洞 3
    33OOX打开洞 2
    44XOX盖上洞 1
    55XXX盖上洞 2
    66XXO打开洞 3
    77XOO打开洞 2
    88OOO打开洞 1,恢复到原来的状态

    现在,奶牛们厌倦了这个游戏,它们想找你帮忙。

    给定 nn,求游戏的有效解决方案序列。如果有多个解决方案,则返回任意一个

    输入格式

    仅一行,一个整数 nn。

    输出格式

    共 2^n+12n+1 行,每行一个长度为 nn 的字符串,其中只包含字符 O 和 X,该行中的第 ii 个字符表示第 ii 个孔在此状态下是被覆盖还是未覆盖,第一行和最后一行必须全部都是 O

    输入输出样例

    输入 #1复制

    3

    输出 #1复制

    OOO
    OXO
    OXX
    OOX
    XOX
    XXX
    XXO
    XOO
    OOO
    

    思路:如果去掉两个全都是0的序列的话就是有2^n-1个序列

    状态用1~2^n的二进制数表示

    然后我们就找1~2^n的全排列中满足相邻的两个数相差一位的序列

    用一个数来记录一下,找到了就更改一下,每次递归首先判断一下是否已经更改,如果更改了就直接返回

    用一个数组来记录2^n-1个状态的方案序列

    然后每次递归记录的是当前搜到第几个状态,如果搜到了最后的先输出全是0再输出序列再输出全是0

    因为我们要找的是1~2^n的二进制表示的状态,为了避免搜到0我们先把0标记为已经用过

    然后我们开始从第一个序列递归

    设每次递归到第u个状态的数,那我们就一位一位看第u-1个状态的数

    如果第i位的数是1就减掉第i位的1递归,如果是0就加上第i位上的1递归

    具体见代码注释

    1. /*
    2. .----------------. .----------------. .----------------. .----------------.
    3. | .--------------. || .--------------. || .--------------. || .--------------. |
    4. | | ________ | || | _________ | || | ____ ____ | || | ____ | |
    5. | | |_ ___ `. | || | |_ ___ | | || ||_ \ / _|| || | .' `. | |
    6. | | | | `. \ | || | | |_ \_| | || | | \/ | | || | / .--. \ | |
    7. | | | | | | | || | | _| _ | || | | |\ /| | | || | | | | | | |
    8. | | _| |___.' / | || | _| |___/ | | || | _| |_\/_| |_ | || | \ `--' / | |
    9. | | |________.' | || | |_________| | || ||_____||_____|| || | `.____.' | |
    10. | | | || | | || | | || | | |
    11. | '--------------' || '--------------' || '--------------' || '--------------' |
    12. '----------------' '----------------' '----------------' '----------------'
    13. */
    14. #include
    15. #include
    16. #include
    17. #include
    18. #include
    19. #include
    20. #include
    21. #include
    22. #include
    23. #include
    24. #define int long long
    25. #define lowbit(x) x&(-x)
    26. #define PI 3.1415926535
    27. #define endl "\n"
    28. using namespace std;
    29. typedef long long ll;
    30. typedef pair<int,int> pii;
    31. int gcd(int a,int b) {
    32. return b? gcd(b,a%b):a;
    33. }
    34. /*
    35. int dx[8]={-2,-2,-1,1,2,2,-1,1};
    36. int dy[8]={-1,1,2,2,1,-1,-2,-2};
    37. int dx[4]={0,-1,0,1};
    38. int dy[4]={-1,0,1,0};
    39. int dx[8]={-1,1,0,0,-1,-1,1,1};
    40. int dy[8]={0,0,-1,1,-1,1,-1,1};
    41. */
    42. //int e[N],ne[N],h[N],idx,w[N];
    43. /*void add(int a,int b,int c){
    44. e[idx]=b;
    45. w[idx]=c;
    46. ne[idx]=h[a];
    47. h[a]=idx++;
    48. }
    49. */
    50. const int N=1<<15+5;
    51. int m,f,n;
    52. int c[N];//记录每个状态是否出来过
    53. int a[N];
    54. void dfs(int u){//记录当前状态的下标
    55. if(f)return ;
    56. if(u==m){
    57. f=1;
    58. for(int i=0;i"O";
    59. cout<
    60. for(int i=1;i
    61. for(int j=0;j
    62. if((a[i]>>j)&1)cout<<"X";
    63. else cout<<"O";
    64. }
    65. cout<
    66. }
    67. for(int i=0;i"O";
    68. cout<
    69. return ;
    70. }
    71. int now;
    72. for(int i=0;i
    73. if((a[u-1]>>i)&1){
    74. now=a[u-1]-(1<
    75. }else now=a[u-1]+(1<
    76. if(!c[now]){//如果没被用过
    77. c[now]=1;//标记一下
    78. a[u]=now;//现在这个状态是now
    79. dfs(u+1);//递归下一位
    80. c[now]=0;//如果找不到正确答案那就回溯
    81. a[u]=0;
    82. }
    83. }
    84. return ;
    85. }
    86. void sove(){
    87. cin>>n;
    88. m=1<
    89. c[0]=1;
    90. dfs(1);
    91. }
    92. signed main(){
    93. sove();
    94. return 0;
    95. }

  • 相关阅读:
    日常问题: 上线确认
    4 OpenCV实现多目三维重建(多张图片增量式生成稀疏点云)【附源码】
    Springboot、Mybatis(Mybatis-plus) 、Mysql
    RAG之微调垂域BGE的经验之谈
    83页智慧小区智能化设计方案
    计算机网络-应用层(3)
    使用 SwiftUI 构建可搜索列表,为您的 iOS 应用程序创建具有自动完成功能的可搜索列表(教程含源码)
    AI绘画想生成好看的图,这些技巧不得不掌握
    移动WEB开发之流式布局--移动WEB开发之flex布局--携程网首页案例制作
    springboot(spring)整合redis(集群)、细节、底层配置讲解
  • 原文地址:https://blog.csdn.net/qq_61903556/article/details/127592891