• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            f(sixleaves) = sixleaves

            重劍無鋒 大巧不工

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              95 隨筆 :: 0 文章 :: 7 評論 :: 0 Trackbacks
            /Files/sixleaves/253.pdf 
            題目在上面,可以自己下載,這道一開始沒什么思路,后來仔細想想,突然有了點靈感,但是還是找不到比較簡單的辦法
            程序還有優化的地步,用到的全局變量有點多。
            我的思路是:每個數字都有一個位于Top也就是最頂得時候,只要在這時候,豎直旋轉4次,分別判斷就可以知道是否存在相同的cube了。
            程序主體框架挺清晰的,但是有一點就是下標沒處理好,有興趣的,可以自己統一一下。
            by sixleaves
             1 #include <stdio.h>
             2 
             3 //  枚舉各個數字位于"上"的一種可能情況
             4 //  該情況下,各個數字所處的位置
             5 int cubeTop[7][7] = {
             6     {0,0,0,0,0,0,0},
             7     {0,1,2,3,4,5,6},
             8     {0,2,6,3,4,1,5},
             9     {0,3,2,6,1,5,4},
            10     {0,4,2,1,6,5,3},
            11     {0,5,1,3,4,6,2},
            12     {0,6,5,3,4,2,1}
            13 };
            14 
            15 
            16 int lastCube[7] = {0};
            17 int curCube[7] = {0};
            18 
            19 int isFind;
            20 
            21 // [0,6)  [6,12)--為另外一個cube
            22 char s[15] = {0};
            23 void turn();
            24 void update();
            25 int isSameCube();
            26 int main() {
            27     
            28     while (scanf("%s",s) != EOF) {
            29     
            30         // 枚舉top面數字
            31         isFind = 0;
            32         for (int i = 1; i <=6; i++) {
            33             
            34             //  初始化當前篩子
            35             for (int k = 1; k <= 6; k++) {
            36                 lastCube[k] = curCube[k] = cubeTop[i][k];
            37             }
            38             
            39             // 豎直轉動4次篩子
            40             for (int j = 0; j < 4; j++) {
            41                 
            42                 turn();
            43                 
            44                 if (isSameCube()) {
            45                     isFind = 1;
            46                     break;
            47                 }
            48                 
            49             }
            50             
            51             if (isFind) {
            52                 break;
            53             }
            54         }
            55         
            56         printf( isFind == 1? "TRUE\n" : "FALSE\n");
            57         
            58     }
            59     return 0;
            60 }
            61 
            62 int isSameCube() {
            63     
            64     //分別比較對應6個面
            65     for (int i = 0; i < 6; i++) {
            66         if (s[curCube[i + 1] - 1] != s[i + 6])
            67             return 0;
            68     }
            69     return 1;
            70 }
            71 
            72 void turn() {
            73     
            74     curCube[2] = lastCube[3];
            75     curCube[4] = lastCube[2];
            76     curCube[5] = lastCube[4];
            77     curCube[3] = lastCube[5];
            78     //  更新lastCube
            79     update();
            80 }
            81 
            82 void update() {
            83     
            84     lastCube[2] = curCube[2];
            85     lastCube[4] = curCube[4];
            86     lastCube[5] = curCube[5];
            87     lastCube[3] = curCube[3];
            88     
            89 }
            posted on 2015-02-08 01:42 swp 閱讀(193) 評論(0)  編輯 收藏 引用 所屬分類: algorithm
            精品久久久久久无码人妻蜜桃| 久久久噜噜噜www成人网| 久久久久亚洲AV成人网| 久久精品亚洲乱码伦伦中文| 一级做a爰片久久毛片毛片| 国内精品伊人久久久久777| www.久久热.com| 亚洲精品99久久久久中文字幕 | 亚洲а∨天堂久久精品9966| 国产成人综合久久精品红| 久久精品国产精品亚洲毛片| 久久福利片| 人人狠狠综合久久亚洲婷婷| 99久久这里只精品国产免费| 久久99精品国产99久久6男男| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 久久SE精品一区二区| 高清免费久久午夜精品| 久久久久青草线蕉综合超碰| 久久精品国产清自在天天线| 久久夜色tv网站| 1000部精品久久久久久久久| 久久亚洲AV成人无码国产| 中文成人久久久久影院免费观看| 伊人热人久久中文字幕| 久久婷婷成人综合色综合| 综合久久国产九一剧情麻豆| 欧美久久综合九色综合| 精品熟女少妇aⅴ免费久久| 精品久久久久久综合日本| 久久亚洲私人国产精品| 亚洲国产精品无码久久久不卡| 亚洲国产成人久久一区WWW| 成人精品一区二区久久| 久久精品国产一区二区三区不卡 | 一本色道久久HEZYO无码| 久久91精品国产91| 性做久久久久久久| 日韩久久久久久中文人妻| 久久香蕉国产线看观看精品yw | 久久无码人妻精品一区二区三区|