摘要:據(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)簽。
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運行的結(jié)果:= 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; } })();
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/87030.html
摘要:回溯法是一種選優(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...
摘要:最近遇到的前端面試題更新版前端掘金個人博客已上線,歡迎前去訪問評論無媛無故的個人博客以下內(nèi)容非本人原創(chuàng),是整理后覺得更容易理解的版本,歡迎補充。 一道面試題引發(fā)的對 javascript 類型轉(zhuǎn)換的思考 - 前端 - 掘金 最近群里有人發(fā)了下面這題:實現(xiàn)一個函數(shù),運算結(jié)果可以滿足如下預(yù)期結(jié)果: ... 收集 JavaScript 各種疑難雜癥的問題集錦 - 前端 - 掘金 從原博客遷移...
摘要:最近遇到的前端面試題更新版前端掘金個人博客已上線,歡迎前去訪問評論無媛無故的個人博客以下內(nèi)容非本人原創(chuàng),是整理后覺得更容易理解的版本,歡迎補充。 一道面試題引發(fā)的對 javascript 類型轉(zhuǎn)換的思考 - 前端 - 掘金 最近群里有人發(fā)了下面這題:實現(xiàn)一個函數(shù),運算結(jié)果可以滿足如下預(yù)期結(jié)果: ... 收集 JavaScript 各種疑難雜癥的問題集錦 - 前端 - 掘金 從原博客遷移...
閱讀 3073·2021-10-12 10:12
閱讀 1582·2021-09-09 11:39
閱讀 1910·2019-08-30 15:44
閱讀 2354·2019-08-29 15:23
閱讀 2906·2019-08-29 15:18
閱讀 2973·2019-08-29 13:02
閱讀 2698·2019-08-26 18:36
閱讀 747·2019-08-26 12:08