• <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>

            我希望你是我獨家記憶

            一段永遠封存的記憶,隨風而去
            posts - 263, comments - 31, trackbacks - 0, articles - 3
               :: 首頁 :: 新隨筆 ::  :: 聚合  :: 管理

            USACO——441——( 構(gòu)造法 )

            Posted on 2008-08-12 21:10 Hero 閱讀(138) 評論(0)  編輯 收藏 引用 所屬分類: 代碼如詩--ACM

            ?

            /*
            ID:?wangzha4
            LANG:?C++
            TASK:?shuttle
            */
            /*
            Test?1:?TEST?OK?[0.000?secs,?2716?KB]
            Test?2:?TEST?OK?[0.011?secs,?2712?KB]
            Test?3:?TEST?OK?[0.000?secs,?2712?KB]
            Test?4:?TEST?OK?[0.000?secs,?2712?KB]
            Test?5:?TEST?OK?[0.022?secs,?2716?KB]
            Test?6:?TEST?OK?[0.000?secs,?2716?KB]
            Test?7:?TEST?OK?[0.000?secs,?2712?KB]
            Test?8:?TEST?OK?[0.000?secs,?2716?KB]
            Test?9:?TEST?OK?[0.022?secs,?2716?KB]
            Test?10:?TEST?OK?[0.000?secs,?2712?KB]
            */
            // *******************************************************
            //
            題目用構(gòu)造法解決--第一次了解這種方法
            //
            以“空白”的位置為關心點
            //
            ?4??3??5??6??4??2??1??3??5??7??6??4??2??3??5??4
            //
            -1?+2?+1?-2?-2?-1?+2?+2?+2?-1?-2?-2?-2?+1?+2?-1
            //
            第一個“-1”之后有?1?--?2
            //
            第二個“1”之后有??2?--?-2
            //
            第三個“-1”之后有?3?--?2?--?達到inn==3的最高點然后開始衰減
            //
            第四個“-1”之后有?2?--?-2
            //
            第五個“1”之后有??1?--?2
            //
            第六個“-1”之后什么都沒有


            //
            細節(jié)注意?:?
            //
            1.?不能定義stime,那是標準的函數(shù),定義sntime
            // 2.?int?sntime?;

            /*
            ******************************************************
            另一種解法?:?--?以每次移動的棋子個數(shù)為參考點

            1.??無論移動什么棋子,以每一次換顏色為界,每次移動數(shù)目為1,2,3……n,n,n……,3,2,1
            2.??第一次移動白色棋子,最后一次也是的。

            例如當n=4時

            1.??將一顆白子右移
            2.??將兩顆黑子依次左移
            3.??將三顆白子依次右移
            4.??將四顆黑子依次左移
            5.??將四顆白子依次右移
            6.??將四顆黑子依次左移
            ……
            2*n+1?將最后一顆白子右移
            ******************************************************
            */

            #include?
            < cstdio >
            #include?
            < iostream >
            #include?
            < cstring >
            #include?
            < ctime >
            using ? namespace ?std?;
            #define ?NDEBUG


            int ?sntime,?entime?;

            const ? int ?size? = ? 10000
            ?;

            int
            ?inn?;

            int ?count?; // 記錄輸出的第幾個數(shù)

            int ?posi?; // 記錄空位置

            void ?printout()
            {
            ????printf(?
            " %d "
            ,?posi?)?;
            ????count?
            ++
            ?;
            ????
            if (? 0 ? == ?count? % ? 20 ?)????printf(? " \n "
            ?)?;
            ????
            else ????printf(? " ? "
            ?)?;
            }

            int
            ?main()
            {
            ????freopen(?
            " shuttle.in " ,? " r "
            ,?stdin?)?;
            ????freopen(?
            " shuttle.out " , " w "
            ,stdout?)?;

            ????
            while (?cin? >>
            ?inn?)
            ????{
            ????????sntime?
            =
            ?clock()?;

            ????????posi?
            = ?inn? + ? 1 ?; // 空格的位置


            ????????
            int ?change? = ? - 1 ?;

            ????????count?
            = ? 0
            ?;
            ????????
            for (? int ?i = 1 ;?i <= inn;?i ++
            ?)
            ????????{
            ????????????posi?
            = ?posi? +
            ?change?;
            ????????????printout()?;
            ????????????
            for (? int ?j = 1 ;?j <= i;?j ++
            ?)
            ????????????{
            ????????????????posi?
            += ?change? * ?( - 2
            )?;
            ????????????????printout()?;
            ????????????}
            ????????????change?
            = ? -
            change?;
            ????????}

            ????????change?
            = ? -
            change?;
            ????????
            for (? int ?i = inn - 1 ;?i >= 1 ;?i --
            ?)
            ????????{
            ????????????posi?
            +=
            ?change?;
            ????????????printout()?;
            ????????????
            for (? int ?j = i;?j >= 1 ;?j --
            ?)
            ????????????{
            ????????????????posi?
            += ?change? * ? 2
            ?;
            ????????????????printout()?;
            ????????????}
            ????????????change?
            = ? -
            change?;
            ????????}
            ????????printf(?
            " %d\n " ,?posi? +
            ?change?)?;

            ????????entime?
            =
            ?clock()?;

            #ifndef?NDEBUG
            ????????printf(?
            " runtime?==?%ld\n " ,?entime? -
            ?sntime?)?;
            #endif


            ????}
            // while

            ????
            return ? 0 ?;
            }
            久久国产劲爆AV内射—百度| 久久久噜噜噜久久熟女AA片 | 18岁日韩内射颜射午夜久久成人| 2021国内精品久久久久久影院| 久久天天躁狠狠躁夜夜不卡| 91精品国产高清91久久久久久| 国产成人无码精品久久久免费| 久久精品一区二区三区AV| 久久久av波多野一区二区| 日本精品久久久久影院日本 | 久久久精品国产亚洲成人满18免费网站 | 亚洲精品tv久久久久| 精品久久久久久久无码 | 久久丝袜精品中文字幕| 波多野结衣中文字幕久久| 久久精品视频一| 精品久久人人做人人爽综合| 国产午夜精品久久久久免费视| 久久久久久免费视频| 久久天天日天天操综合伊人av| 色综合久久中文色婷婷| 国产情侣久久久久aⅴ免费| 三级三级久久三级久久| 久久久久免费视频| 久久97久久97精品免视看秋霞| 久久精品国产清高在天天线| 亚洲va中文字幕无码久久不卡 | 91精品国产高清久久久久久io| 欧美精品国产综合久久| 国产精品99久久久久久宅男小说| 久久这里有精品视频| 亚洲第一永久AV网站久久精品男人的天堂AV | 久久精品人人做人人爽97 | 无码超乳爆乳中文字幕久久| 久久久青草青青国产亚洲免观| 夜夜亚洲天天久久| 久久线看观看精品香蕉国产| 94久久国产乱子伦精品免费| 久久国产成人午夜aⅴ影院| 日本久久中文字幕| 久久久亚洲裙底偷窥综合 |