欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++實(shí)現(xiàn)LeetCode(48.旋轉(zhuǎn)圖像)

 更新時(shí)間:2021年07月15日 15:32:06   作者:Grandyang  
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(48.旋轉(zhuǎn)圖像),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

[LeetCode] 48. Rotate Image 旋轉(zhuǎn)圖像

You are given an n x n 2D matrix representing an image.

Rotate the image by 90 degrees (clockwise).

Note:

You have to rotate the image in-place, which means you have to modify the input 2D matrix directly. DO NOT allocate another 2D matrix and do the rotation.

Example 1:

Given input matrix =
[
[1,2,3],
[4,5,6],
[7,8,9]
],

rotate the input matrix in-place such that it becomes:
[
[7,4,1],
[8,5,2],
[9,6,3]
]

Example 2:

Given input matrix =
[
[ 5, 1, 9,11],
[ 2, 4, 8,10],
[13, 3, 6, 7],
[15,14,12,16]
],

rotate the input matrix in-place such that it becomes:
[
[15,13, 2, 5],
[14, 3, 4, 1],
[12, 6, 8, 9],
[16, 7,10,11]
]

在計(jì)算機(jī)圖像處理里,旋轉(zhuǎn)圖片是很常見(jiàn)的,由于圖片的本質(zhì)是二維數(shù)組,所以也就變成了對(duì)數(shù)組的操作處理,翻轉(zhuǎn)的本質(zhì)就是某個(gè)位置上數(shù)移動(dòng)到另一個(gè)位置上,比如用一個(gè)簡(jiǎn)單的例子來(lái)分析:

1  2  3       7  4  1 

4  5  6  -->   8  5  2  

7  8  9       9  6  3

對(duì)于90度的翻轉(zhuǎn)有很多方法,一步或多步都可以解,先來(lái)看一種直接的方法,這種方法是按順時(shí)針的順序去覆蓋前面的數(shù)字,從四個(gè)頂角開(kāi)始,然后往中間去遍歷,每次覆蓋的坐標(biāo)都是同理,如下:

(i, j)  <-  (n-1-j, i)  <-  (n-1-i, n-1-j)  <-  (j, n-1-i)

這其實(shí)是個(gè)循環(huán)的過(guò)程,第一個(gè)位置又覆蓋了第四個(gè)位置,這里i的取值范圍是 [0, n/2),j的取值范圍是 [i, n-1-i),至于為什么i和j是這個(gè)取值范圍,為啥i不用遍歷 [n/2, n),若仔細(xì)觀(guān)察這些位置之間的聯(lián)系,不難發(fā)現(xiàn),實(shí)際上j列的范圍 [i, n-1-i) 順時(shí)針?lè)D(zhuǎn) 90 度,正好就是i行的 [n/2, n) 的位置,這個(gè)方法每次循環(huán)換四個(gè)數(shù)字,如下所示:

1  2  3               7  2  1            7  4  1

4  5  6      -->      4  5  6   -->    8  5  2  

7  8  9               9  8  3         9  6  3

解法一:

class Solution {
public:
    void rotate(vector<vector<int>>& matrix) {
        int n = matrix.size();
        for (int i = 0; i < n / 2; ++i) {
            for (int j = i; j < n - 1 - i; ++j) {
                int tmp = matrix[i][j];
                matrix[i][j] = matrix[n - 1 - j][i];
                matrix[n - 1 - j][i] = matrix[n - 1 - i][n - 1 - j];
                matrix[n - 1 - i][n - 1 - j] = matrix[j][n - 1 - i];
                matrix[j][n - 1 - i] = tmp;
            }
        }
    }
};

還有一種解法,首先以從對(duì)角線(xiàn)為軸翻轉(zhuǎn),然后再以x軸中線(xiàn)上下翻轉(zhuǎn)即可得到結(jié)果,如下圖所示(其中藍(lán)色數(shù)字表示翻轉(zhuǎn)軸):

1  2  3       9  6  3          7  4  1

4  5  6  -->   8  5  2   -->     8  5  2  

7  8  9       7  4  1          9  6  3

解法二:

class Solution {
public:
    void rotate(vector<vector<int>>& matrix) {
        int n = matrix.size();
        for (int i = 0; i < n - 1; ++i) {
            for (int j = 0; j < n - i; ++j) {
                swap(matrix[i][j], matrix[n - 1- j][n - 1 - i]);
            }
        }
        reverse(matrix.begin(), matrix.end());
    }
};

最后再來(lái)看一種方法,這種方法首先對(duì)原數(shù)組取其轉(zhuǎn)置矩陣,然后把每行的數(shù)字翻轉(zhuǎn)可得到結(jié)果,如下所示(其中藍(lán)色數(shù)字表示翻轉(zhuǎn)軸,Github 上可能無(wú)法顯示顏色,請(qǐng)參見(jiàn)博客園上的帖子):

1  2  3       1  4  7          7  4  1

4  5  6  -->   2  5  8   -->     8  5  2  

7  8  9       3  6  9           9  6  3

解法三:

class Solution {
public:
    void rotate(vector<vector<int>>& matrix) {
        int n = matrix.size();
        for (int i = 0; i < n; ++i) {
            for (int j = i + 1; j < n; ++j) {
                swap(matrix[i][j], matrix[j][i]);
            }
            reverse(matrix[i].begin(), matrix[i].end());
        }
    }
};

到此這篇關(guān)于C++實(shí)現(xiàn)LeetCode(48.旋轉(zhuǎn)圖像)的文章就介紹到這了,更多相關(guān)C++實(shí)現(xiàn)旋轉(zhuǎn)圖像內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語(yǔ)言對(duì)組文件處理的相關(guān)函數(shù)小結(jié)

    C語(yǔ)言對(duì)組文件處理的相關(guān)函數(shù)小結(jié)

    這篇文章主要介紹了C語(yǔ)言對(duì)組文件處理的相關(guān)函數(shù)小結(jié),包括setgrent()函數(shù)和getgrent()函數(shù)以及endgrent()函數(shù),需要的朋友可以參考下
    2015-08-08
  • VC隨機(jī)函數(shù)srand和rand用法

    VC隨機(jī)函數(shù)srand和rand用法

    VC中隨機(jī)函數(shù)最常用就是srand和rand(實(shí)際上是屬于標(biāo)準(zhǔn)C函數(shù)),其中srand負(fù)責(zé)設(shè)置隨機(jī)種子,rand則負(fù)責(zé)生成隨機(jī)數(shù)。使用此二隨機(jī)函數(shù)需要包含<stdlib.h>頭文件
    2016-11-11
  • C++Vector容器常用函數(shù)接口詳解

    C++Vector容器常用函數(shù)接口詳解

    最近我學(xué)習(xí)了C++中的STL庫(kù)中的vector容器,對(duì)于常用容器,我們不僅要會(huì)使用其常用的函數(shù)接口,我們還有明白這些接口在其底層是如何實(shí)現(xiàn)的。所以特意整理出來(lái)一篇博客供我們學(xué)習(xí)
    2022-08-08
  • C語(yǔ)言中條件判斷的正確使用姿勢(shì)

    C語(yǔ)言中條件判斷的正確使用姿勢(shì)

    在C語(yǔ)言中,有三種條件判斷結(jié)構(gòu):if語(yǔ)句、if-else語(yǔ)句和switch語(yǔ)句,這篇文章主要來(lái)和大家講解一下它們的正確使用姿勢(shì),需要的可以參考一下
    2023-05-05
  • 利用C語(yǔ)言實(shí)現(xiàn)猜數(shù)字游戲

    利用C語(yǔ)言實(shí)現(xiàn)猜數(shù)字游戲

    這篇文章主要為大家詳細(xì)介紹了利用C語(yǔ)言實(shí)現(xiàn)猜數(shù)字游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-02-02
  • c++ 類(lèi)和對(duì)象總結(jié)

    c++ 類(lèi)和對(duì)象總結(jié)

    這篇文章主要介紹了c++ 類(lèi)和對(duì)象總結(jié)一,需要的朋友可以參考下
    2020-01-01
  • C++中構(gòu)造函數(shù)重載

    C++中構(gòu)造函數(shù)重載

    這篇文章主要介紹了C++中構(gòu)造函數(shù)重載的相關(guān)資料,十分的詳細(xì),需要的朋友可以參考下
    2015-06-06
  • C++11 線(xiàn)程同步接口std::condition_variable和std::future的簡(jiǎn)單使用示例詳解

    C++11 線(xiàn)程同步接口std::condition_variable和std::future的簡(jiǎn)單使用示例詳

    本文介紹了std::condition_variable和std::future在C++中的應(yīng)用,用于線(xiàn)程間的同步和異步執(zhí)行,通過(guò)示例代碼,展示了如何使用std::condition_variable的wait和notify接口進(jìn)行線(xiàn)程間同步
    2024-09-09
  • Qt的Qss用法小結(jié)

    Qt的Qss用法小結(jié)

    Qt的Qss是一種用于定義用戶(hù)界面的樣式表語(yǔ)言,本文主要介紹了Qt的Qss用法小結(jié),非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2023-06-06
  • 基于Matlab圖像處理的公路裂縫檢測(cè)實(shí)現(xiàn)

    基于Matlab圖像處理的公路裂縫檢測(cè)實(shí)現(xiàn)

    隨著公路的大量投運(yùn),公路日常養(yǎng)護(hù)和管理已經(jīng)成為制約公路運(yùn)營(yíng)水平提高的瓶頸,特別是路面狀態(tài)采集、檢測(cè)維護(hù)等工作更是對(duì)傳統(tǒng)的公路運(yùn)維模式提出了挑戰(zhàn)。這篇文章主要介紹了如何通過(guò)Matlab圖像處理實(shí)現(xiàn)公路裂縫檢測(cè),感興趣的可以了解一下
    2022-02-02

最新評(píng)論