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

            This blog has been shut down permanently.

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              13 隨筆 :: 0 文章 :: 25 評(píng)論 :: 0 Trackbacks

            1   2   3     4
            12 13  14   5
            11 16  15   6
            10  9    8    7  

            這種情況用模擬比較好推出,以1為坐標(biāo)原點(diǎn),一次遞增,遇到邊界則轉(zhuǎn)向

            #include<stdio.h>
            #include
            <string.h>
            #define MAX_SIZE 100
            const int intx[]= {0,1,0,-1};
            const int inty[]= {1,0,-1,0};
            int main() 

               
            int dir,i,j,n,data,x,y,nextx,nexty;
               
            int arr[MAX_SIZE][MAX_SIZE];
               
            /*Read size*/
               printf(
            "please input the size\n");
               scanf(
            "%d",&n);
               
            /*Init*/
               x
            = y= 0;
               dir
            = 0;
               memset(arr,
            0,sizeof(arr));
               
            /*fill*/
               
            for(data=1; data<=n*n; data++)
               
            {
                   arr[x][y]
            = data;
                   nextx
            = x+intx[dir];
                   nexty
            = y+inty[dir];
                   
            if(arr[nextx][nexty] || nextx>=|| nexty>=|| nextx<0 || nexty<0)
                   
            {
                       dir
            ++;
                       
            if(dir==4)dir=0;
                   }

                   x
            += intx[dir];
                   y
            += inty[dir];
               }

               
            for(i=0; i<n; i++)
               
            {
                   
            for(j=0; j<n; j++)
                       printf(
            "%d\t",arr[i][j]);
                   printf(
            "\n");
               }

            }

             

            如果碰到另外一種情況就麻煩多了

                      21  22................
                       20  7  8  9  10
                       19  6  1  2  11
                       18  5  4  3  12
                       17  16 15 14 13

            如果從中間開始模擬

            從原點(diǎn)1開始,看方向的變化:右下左上;行走的步數(shù):11223344……

             公式:n^2= 1+1+2+2+...+n-1+n-1+n(第一種情況也有用到)

            有了公式,那就可以先算出最大的data是多少,這樣又轉(zhuǎn)換為第一種方法了。

            如果沒有公式,單純對(duì)行為進(jìn)行模擬難度很大,不過還是可以實(shí)現(xiàn)的。

            現(xiàn)在暫時(shí)還沒有想到實(shí)現(xiàn)的方法,想到以后再補(bǔ)充吧。
             

            posted on 2009-11-15 16:02 iZ 閱讀(3365) 評(píng)論(4)  編輯 收藏 引用 所屬分類: 『Algorithm,Data Structure in C++』

            評(píng)論

            # re: 螺旋矩陣的算法 2009-11-17 16:39 qinqing1984
            這個(gè)模型比較簡單,從中間向外轉(zhuǎn),就有點(diǎn)復(fù)雜了  回復(fù)  更多評(píng)論
              

            # re: 螺旋矩陣的算法 2009-11-18 17:02 xuxiandi
            從中間向外轉(zhuǎn)....不就是從外向中間轉(zhuǎn)..然后遞減嗎?  回復(fù)  更多評(píng)論
              

            # re: 螺旋矩陣的算法 2009-11-19 13:44 iSsay
            @xuxiandi
            我在想如果沒有數(shù)學(xué)公式該怎么模擬呢

            現(xiàn)在還想不出來,因?yàn)檠h(huán)控制不好弄,要用到很多變量標(biāo)記  回復(fù)  更多評(píng)論
              

            # re: 螺旋矩陣的算法 2012-10-22 00:07 光亮
            if(arr[nextx][nexty] || nextx>=n || nexty>=n || nextx<0 || nexty<0)

            作者這句話有點(diǎn)小錯(cuò)誤。。第一個(gè)判斷放到最后更好  回復(fù)  更多評(píng)論
              

            亚洲一区精品伊人久久伊人 | 成人国内精品久久久久影院| 久久人妻少妇嫩草AV无码专区| 久久婷婷综合中文字幕| 伊人久久大香线蕉影院95| 久久精品国产久精国产果冻传媒 | 91精品免费久久久久久久久| 香港aa三级久久三级老师2021国产三级精品三级在 | 日批日出水久久亚洲精品tv| 久久久久久国产精品免费无码 | 久久亚洲国产精品一区二区| 一本久久a久久精品综合香蕉| 伊人久久无码中文字幕| 国内精品久久久久久久影视麻豆| 亚洲国产成人久久笫一页| 国产精品久久久久影视不卡| 久久久久久久91精品免费观看| 91久久婷婷国产综合精品青草| 中文字幕久久亚洲一区| 一级做a爰片久久毛片人呢| 日产精品久久久久久久性色| 欧美亚洲国产精品久久久久| 大美女久久久久久j久久| 久久精品国产亚洲AV无码麻豆| 无码人妻久久一区二区三区蜜桃| 91久久精品无码一区二区毛片| 国产午夜久久影院| 国产精品99久久99久久久| 久久亚洲私人国产精品| 人妻久久久一区二区三区| 亚洲日韩中文无码久久| 亚洲国产精品成人久久| 亚洲av伊人久久综合密臀性色| 久久精品国产AV一区二区三区| 狠狠色婷婷久久一区二区| 亚洲伊人久久精品影院| 狠狠色婷婷久久一区二区| 人妻精品久久无码区| 精品久久8x国产免费观看| 青青青青久久精品国产| 精品久久人人妻人人做精品|