成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

前端面試的一道算法題(使用canvas解答)

hot_pot_Leo / 3135人閱讀

摘要:據(jù)了解,現(xiàn)在前端面試也喜歡考算法題了。下面說一個跟前端有點相關(guān)并且有點趣的一道算法題。遍歷二維數(shù)組連續(xù)的個數(shù)連續(xù)的個數(shù)形狀的總數(shù)第幾個形狀形狀的面積最后的代碼圖片路徑讀取整張圖片的像素。

據(jù)了解,現(xiàn)在前端面試也喜歡考算法題了。前幾天去面試,果不其然的,面試官給我四道算法題,讓我自己回去做。下面說一個跟前端有點相關(guān)并且有點趣的一道算法題。

題目:

平面上有若干個不特定的形狀,如下圖所示。請寫程序求出物體的個數(shù),以及每個不同物體的面積。

分析

想要知道有多少個圖形,想到的就是先獲取圖片中的每一個像素點然后判獲取像素點的背景顏色(RGBA)。想要獲得圖片中的每一個像素點,那就可以聯(lián)想到使用h5的canvas。
如下:

菜鳥教程中canvas的getimagedata方法

書寫html標(biāo)簽。

 對不你,你的瀏覽器不支持Canvas 

js獲取canvas對象

let ctxt = canvas.getContext("2d");

js創(chuàng)建image對象

let img = new Image;
img.src = "./image.png"; //圖片路徑
img.onload = function(){}  //加載成功后的執(zhí)行函數(shù),之后的代碼就寫在其中

創(chuàng)建存儲圖片像素點的二維數(shù)組

let coordinates = [];
for(let i=0; i<200; i++){
       coordinates[i] = [];
}

獲取像素點,也就是使用getimagedata方法。

ctxt.drawImage(img, 0, 0);  //將圖片畫如canvas
let data = ctxt.getImageData(0, 0, 350, 200).data;//讀取整張圖片的像素。

將像素存入二維數(shù)組

let x=0,y=0;  //二維數(shù)組的行和列, x:列  y:行
for(let i =0,len = data.length; i= 350){
            x = 0;
            y++;
        }
}

目前代碼如下:

(function(){
        let ctxt = canvas.getContext("2d");
        let img = new Image;
        let coordinates = [];
        let h = 200,
            w = 350;
        for(let i=0; i<200; i++){
            coordinates[i] = [];
        }
        img.src = "./image.png"; //圖片路徑
        img.onload = function(){
            ctxt.drawImage(img, 0, 0);
            let data = ctxt.getImageData(0, 0, 350, 200).data;//讀取整張圖片的像素。
            let x=0,y=0;
            for(let i =0,len = data.length; i= 350){
                        x = 0;
                        y++;
                    }
                }
                console.log(coordinates);
        }
    })();

如圖:

構(gòu)成類似如下二維數(shù)組:

 0,0,0,0,0,0,0,0,0,0,0,0
 0,0,1,1,1,0,0,0,0,0,0,0
 0,1,1,1,1,0,0,0,0,0,0,0
 0,1,1,1,0,0,0,1,1,1,1,0
 0,0,0,0,0,0,1,1,1,0,0,0
 0,0,0,0,0,0,1,1,1,0,0,0
 0,0,0,0,0,0,0,0,0,0,0,0

那么我們就只需要知道二維數(shù)組中這種連續(xù)為1的塊有多少個就知道了圖片中形狀有多少個,并且塊中有多少個1,那么這個塊的面積就是1的個數(shù)。

遞歸回溯算法
//計算連續(xù)的面積和個數(shù)
const linkSum = (i,j,num)=>{
        //走過的路就置0
      coordinates[i][j] = 0;
      num++;
      //向上
      if((i+1 < h) && coordinates[i+1][j] == 1){
        num = linkSum(i+1 , j , num);
      }
      //向下
      if((j+1 < w) && coordinates[i][j+1] == 1){
        num = linkSum(i , j+1 , num);
      }
      //向左
      if((i-1 >= 0) && coordinates[i-1][j] == 1){
        num = linkSum(i-1 , j , num);
      }
      //向右
    if((j-1 >= 0) && coordinates[i][j-1] == 1){
        num = linkSum(i , j-1 , num);
    }

    return num;
}

不熟悉的,直接百度就好,這里就不多說了,其實代碼就反應(yīng)了很多信息。

使用算法,統(tǒng)計并計算出結(jié)果。
const getCountAndArea = () =>{
    let sum = [];
    let count = 0;
    for(let i = 0; i < h; i++)  //遍歷二維數(shù)組
    {
      for(let j = 0; j < w; j++)
      {
       //連續(xù)1的個數(shù)
       if(coordinates[i][j] == 1)
       {
        let buf = 0;  //連續(xù)1的個數(shù)
        buf = linkSum(i,j,buf);
        count++;  //形狀的總數(shù)
        sum.push({
            index: count,   //第幾個形狀
            area: buf         //形狀的面積
        });
       }
      }
    }
    return {
        count,
        sum
    };
}
最后的代碼
(function(){
        let ctxt = canvas.getContext("2d");
        let img = new Image;
        let coordinates = [];
        let h = 200,
            w = 350;
        for(let i=0; i<200; i++){
            coordinates[i] = [];
        }
        img.src = "./image.png"; //圖片路徑
        img.onload = function(){
            ctxt.drawImage(img, 0, 0);
            let data = ctxt.getImageData(0, 0, 350, 200).data;//讀取整張圖片的像素。
            let x=0,y=0;
            for(let i =0,len = data.length; i= 350){
                        x = 0;
                        y++;
                    }
                }
                // console.log(coordinates);
                let rst = getCountAndArea();
                // console.log(rst);
                console.log("個數(shù): " + rst.count);
                for(let i=0; i{
            let sum = [];
            let count = 0;
            for(let i = 0; i < h; i++)
            {
              for(let j = 0; j < w; j++)
              {
               //連續(xù)1的個數(shù)
               if(coordinates[i][j] == 1)
               {
                let buf = 0;
                buf = linkSum(i,j,buf);
                count++;
                sum.push({
                    index: count,
                    area: buf
                });
               }
              }
            }
            return {
                count,
                sum
            };
        }

        //計算連續(xù)的面積和個數(shù)
        const linkSum = (i,j,num)=>{
            //走過的路就置0
          coordinates[i][j] = 0;
          num++;
          //向上
          if((i+1 < h) && coordinates[i+1][j] == 1){
            num = linkSum(i+1 , j , num);
          }
          //向下
          if((j+1 < w) && coordinates[i][j+1] == 1){
            num = linkSum(i , j+1 , num);
          }
          //向左
          if((i-1 >= 0) && coordinates[i-1][j] == 1){
            num = linkSum(i-1 , j , num);
          }
          //向右
        if((j-1 >= 0) && coordinates[i][j-1] == 1){
            num = linkSum(i , j-1 , num);
        }

        return num;
        }
    })();
運行的結(jié)果:

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/87030.html

相關(guān)文章

  • 深入理解js

    摘要:詳解十大常用設(shè)計模式力薦深度好文深入理解大設(shè)計模式收集各種疑難雜癥的問題集錦關(guān)于,工作和學(xué)習(xí)過程中遇到過許多問題,也解答過許多別人的問題。介紹了的內(nèi)存管理。 延遲加載 (Lazyload) 三種實現(xiàn)方式 延遲加載也稱為惰性加載,即在長網(wǎng)頁中延遲加載圖像。用戶滾動到它們之前,視口外的圖像不會加載。本文詳細(xì)介紹了三種延遲加載的實現(xiàn)方式。 詳解 Javascript十大常用設(shè)計模式 力薦~ ...

    caikeal 評論0 收藏0
  • canvas getImageData 做點有趣

    摘要:回溯法是一種選優(yōu)搜索法,按選優(yōu)條件向前搜索,以達(dá)到目標(biāo)。但當(dāng)探索到某一步時,發(fā)現(xiàn)原先選擇并不優(yōu)或達(dá)不到目標(biāo),就退回一步重新選擇,這種走不通就退回再走的技術(shù)為回溯法。代碼請點這里這里有一個示例,展示下用回溯法怎么找到這些形狀的。 說明 canvas元素標(biāo)簽強大之處在于可以直接在HTML上進行圖形操作,具有極大的應(yīng)用價值。 canvas 可以實現(xiàn)對圖像的像素操作,這就要說到 getImag...

    chenatu 評論0 收藏0
  • 2017 前端面試準(zhǔn)備 - 收藏集 - 掘金

    摘要:最近遇到的前端面試題更新版前端掘金個人博客已上線,歡迎前去訪問評論無媛無故的個人博客以下內(nèi)容非本人原創(chuàng),是整理后覺得更容易理解的版本,歡迎補充。 一道面試題引發(fā)的對 javascript 類型轉(zhuǎn)換的思考 - 前端 - 掘金 最近群里有人發(fā)了下面這題:實現(xiàn)一個函數(shù),運算結(jié)果可以滿足如下預(yù)期結(jié)果: ... 收集 JavaScript 各種疑難雜癥的問題集錦 - 前端 - 掘金 從原博客遷移...

    王晗 評論0 收藏0
  • 2017 前端面試準(zhǔn)備 - 收藏集 - 掘金

    摘要:最近遇到的前端面試題更新版前端掘金個人博客已上線,歡迎前去訪問評論無媛無故的個人博客以下內(nèi)容非本人原創(chuàng),是整理后覺得更容易理解的版本,歡迎補充。 一道面試題引發(fā)的對 javascript 類型轉(zhuǎn)換的思考 - 前端 - 掘金 最近群里有人發(fā)了下面這題:實現(xiàn)一個函數(shù),運算結(jié)果可以滿足如下預(yù)期結(jié)果: ... 收集 JavaScript 各種疑難雜癥的問題集錦 - 前端 - 掘金 從原博客遷移...

    xiaochao 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<