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

            逛奔的蝸牛

            我不聰明,但我會很努力

               ::  :: 新隨筆 ::  ::  :: 管理 ::


            import java.util.Arrays;


            /**

             * @author Biao

             * 

             * 在寫俄羅斯方塊時,可以為每個圖形的每種狀態都定義一個數組來表示(效率高)。

             * 因為每個圖形有四個方向的狀態:上右下左,所以每個圖形要定義四個數組來表示他的狀態。

             * 如果把這些圖形都放在一個方陣中,圖形的重心為方陣的中心,旋轉時繞方陣中心旋轉,

             * 則圖形的四個方向的狀態可以通過旋轉方陣來實現,這樣為每種圖形只需要定義一個狀態數組。

             * 而方陣向左或向右旋轉 90 度通過算法可以很方便的實現。

             * 

             * 一般的如圖像旋轉任意角度 delta,也是要放在一個方陣中進行處理,以方陣的中心為坐標軸原心,

             * 然后使用sin, cos計算出旋轉后的坐標點,取整。

             * 如圖像上某一點離原心的距離為 r, 它的角度為 alpha, 逆時針旋轉 delta:

             * x = r * cos(delta + alpha)

             * y = r * sin(delta + alpha)

             * 可以把2D坐標 (x, y) 歸一化,變成(x, y, 1),然后使用上面的公式計算出旋轉矩陣來計算更為方便。

             */

            public class RotateUtil {

                public static enum Direction { LEFT, RIGHT };

                

                /**

                 * 方陣向右或向左旋轉90度。

                 */

                public static int[][] rotateSquareMatrix(int[][] data, Direction dir) {

                    int len = data.length;

                    int last = len - 1;

                    temp = createTempSquareMatrix(len);

                    

                    // 代碼量換取計算效率

                    if (dir == Direction.LEFT) {

                        // 向左旋轉,第一行變第一列,第二行變第二列

                        for (int i = 0; i < len; ++i) {

                            for (int j = 0; j < len; ++j) {

                                temp[last - j][i] = data[i][j];

                            }

                        }

                    } else if (dir == Direction.RIGHT) {

                        // 向右旋轉,第一行變第四列,第二行變第n - 2列

                        for (int i = 0; i < len; ++i) {

                            for (int j = 0; j < len; ++j) {

                                temp[j][last - i] = data[i][j];

                            }

                        }

                    }

                    

                    // 復制旋轉后的數據

                    for (int i = 0; i < len; ++i) {

                        for (int j = 0; j < len; ++j) {

                            data[i][j] = temp[i][j];

                        }

                    }

                    

                    return data;

                }

                

                public static void printMatrix(int[][] data) {

                    for (int i = 0; i < data.length; ++i) {

                        System.out.println(Arrays.toString(data[i]));

                    }

                }

                private static int[][] createTempSquareMatrix(int size) {

                    if (temp == null || temp.length != size) {

                        temp = new int[size][size];

                    }


                    return temp;

                }

                

                private static int[][] temp = null;

                

                public static void main(String[] args) {

                    // 一般的俄羅斯方式 5 * 5 的方陣正好

                    int[][] data = {

                            {0, 0, 1, 0, 0},

                            {0, 0, 1, 0, 0},

                            {0, 0, 1, 1, 0},

                            {0, 0, 0, 0, 0},

                            {0, 0, 0, 0, 0}

                    };

                    

                    Direction dir = Direction.LEFT;

                    String info = "Rotate " + ((dir == Direction.LEFT) ? "left" : "right");

                    

                    System.out.println("Original Data:");

                    printMatrix(data);

                    

                    System.out.println(info);

                    rotateSquareMatrix(data, dir);

                    printMatrix(data);

                    

                    System.out.println(info);

                    rotateSquareMatrix(data, dir);

                    printMatrix(data);

                    

                    System.out.println(info);

                    rotateSquareMatrix(data, dir);

                    printMatrix(data);

                    

                    System.out.println(info);

                    rotateSquareMatrix(data, dir);

                    printMatrix(data);

                    

                    System.out.println("-------------------------------------------");

                    dir = Direction.RIGHT;

                    info = "Rotate " + ((dir == Direction.LEFT) ? "left" : "right");

                    

                    System.out.println("Original Data:");

                    printMatrix(data);

                    

                    System.out.println(info);

                    rotateSquareMatrix(data, dir);

                    printMatrix(data);

                    

                    System.out.println(info);

                    rotateSquareMatrix(data, dir);

                    printMatrix(data);

                    

                    System.out.println(info);

                    rotateSquareMatrix(data, dir);

                    printMatrix(data);

                    

                    System.out.println(info);

                    rotateSquareMatrix(data, dir);

                    printMatrix(data);

                }

            }


            測試結果:

            Original Data:

            [0, 0, 1, 0, 0]

            [0, 0, 1, 0, 0]

            [0, 0, 1, 1, 0]

            [0, 0, 0, 0, 0]

            [0, 0, 0, 0, 0]

            Rotate left

            [0, 0, 0, 0, 0]

            [0, 0, 1, 0, 0]

            [1, 1, 1, 0, 0]

            [0, 0, 0, 0, 0]

            [0, 0, 0, 0, 0]

            Rotate left

            [0, 0, 0, 0, 0]

            [0, 0, 0, 0, 0]

            [0, 1, 1, 0, 0]

            [0, 0, 1, 0, 0]

            [0, 0, 1, 0, 0]

            Rotate left

            [0, 0, 0, 0, 0]

            [0, 0, 0, 0, 0]

            [0, 0, 1, 1, 1]

            [0, 0, 1, 0, 0]

            [0, 0, 0, 0, 0]

            Rotate left

            [0, 0, 1, 0, 0]

            [0, 0, 1, 0, 0]

            [0, 0, 1, 1, 0]

            [0, 0, 0, 0, 0]

            [0, 0, 0, 0, 0]

            -------------------------------------------

            Original Data:

            [0, 0, 1, 0, 0]

            [0, 0, 1, 0, 0]

            [0, 0, 1, 1, 0]

            [0, 0, 0, 0, 0]

            [0, 0, 0, 0, 0]

            Rotate right

            [0, 0, 0, 0, 0]

            [0, 0, 0, 0, 0]

            [0, 0, 1, 1, 1]

            [0, 0, 1, 0, 0]

            [0, 0, 0, 0, 0]

            Rotate right

            [0, 0, 0, 0, 0]

            [0, 0, 0, 0, 0]

            [0, 1, 1, 0, 0]

            [0, 0, 1, 0, 0]

            [0, 0, 1, 0, 0]

            Rotate right

            [0, 0, 0, 0, 0]

            [0, 0, 1, 0, 0]

            [1, 1, 1, 0, 0]

            [0, 0, 0, 0, 0]

            [0, 0, 0, 0, 0]

            Rotate right

            [0, 0, 1, 0, 0]

            [0, 0, 1, 0, 0]

            [0, 0, 1, 1, 0]

            [0, 0, 0, 0, 0]

            [0, 0, 0, 0, 0]


             


            posted on 2010-10-31 05:52 逛奔的蝸牛 閱讀(1553) 評論(0)  編輯 收藏 引用 所屬分類: Java
            久久综合伊人77777麻豆| 97久久国产亚洲精品超碰热| 中文字幕亚洲综合久久| 99久久99久久精品国产片果冻| 无码人妻精品一区二区三区久久久| 久久九九久精品国产| 国产精品免费久久| 久久精品国产99久久丝袜| 久久婷婷五月综合97色直播| 久久久精品国产亚洲成人满18免费网站 | 伊人久久精品影院| 伊色综合久久之综合久久| 蜜臀久久99精品久久久久久| 亚洲精品无码久久不卡| 中文成人无码精品久久久不卡| 亚洲中文字幕伊人久久无码 | 久久精品亚洲福利| 亚洲国产天堂久久综合| 国产激情久久久久久熟女老人| 国产成人精品综合久久久| 国产精品久久久久jk制服| 大香网伊人久久综合网2020| 日本精品久久久久久久久免费| 亚洲精品美女久久久久99小说 | 久久久久久久尹人综合网亚洲| 国产亚州精品女人久久久久久 | 久久精品18| 亚洲色大成网站www久久九| 国产精品久久久久无码av| 九九热久久免费视频| 色欲av伊人久久大香线蕉影院| 97久久香蕉国产线看观看| 亚洲国产成人久久精品99| 日韩亚洲欧美久久久www综合网| 久久香蕉国产线看观看猫咪?v| 人妻精品久久久久中文字幕69 | 久久久久无码中| 99久久99这里只有免费费精品| 久久久这里有精品中文字幕| 久久久久亚洲AV成人片| 麻豆久久久9性大片|