摘要:之前介紹,機試題主要考察分析和邏輯能力,不會用到復雜的算法,而且現(xiàn)場也不能使用除了輸入輸出流之外的其他的庫或包。判斷條件為,實際調(diào)試時出錯,這塊分析不嚴謹。
3月1日,三星電子研究所公司機試。
之前HR介紹,機試題主要考察分析和邏輯能力,不會用到復雜的算法,而且現(xiàn)場也不能使用除了輸入輸出流之外的其他的庫或包。
在公司的一間機試屋子考試,有VisualStudio和Eclipse兩種編譯器可選。機試有專門的系統(tǒng),可以查看題目,并且在下方編程(沒有提示,得全程手打,而且不提醒語法錯誤,建議用編譯器),該頁面同時可以進行測試案例調(diào)試,運行后可得編譯結果(會提示語法錯誤和異常)提供參考。調(diào)試次數(shù)不限,提交(submit)次數(shù)為三次,提交后,屏幕會彈出本地10個case的通過情況,通過為pass,后臺還有其他case,所以最終結果還得等總部過幾天的反饋。機試總共3小時,系統(tǒng)界面和題目都是英語,手機得飛行模式,現(xiàn)場提供紙筆。
題目:原題記不太清了,大致意思如下:
給一個10×10的表格(grid),其中放置有2×1的方塊(blocks),方塊和橫豎放置。讓表格中的方塊自由下落(類似俄羅斯方塊),堆積在底部。表格中有方塊占有的格子用1表示,沒有的用0表示。用數(shù)字0-10表示下落后,每列的方塊高度。
圖1:方塊降落前
圖2:方塊降落后
注:題目要求方塊不能全部靠在左側、右側、上側或下側,而且下邊這種連續(xù)放置方塊的情況也不允許(題目中英文沒全看懂,個人理解)。這個條件尤其要注意,中途寫完程序,就是忽略了這個約束,結果老是不對。
輸入輸出1、Input
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 1 0 0 0 1 1 0
0 0 0 1 0 0 0 0 0 0
1 1 0 0 0 0 0 0 0 0
0 0 0 0 1 1 0 0 0 0
0 1 1 0 0 0 0 0 0 0
0 0 0 0 0 0 0 1 0 0
0 0 0 0 0 0 0 1 0 0
0 0 0 0 0 0 0 0 0 0
……
共10個case
2、Output
*1 2212110330個人解法
……
10個case,每個case的結果都按行輸出(*1表示case1)
首先,本題是計算落下方塊的高度。從下往上,方塊是堆疊起來的,也就是說,上層的方塊降落點取決于下層的方塊位置。因此,思路是從下向上,按行迭代分析。再將問題拆解,每行迭代的時候,可以從左向右分析。
設輸入表格元素數(shù)組為A11,輸出的高度數(shù)組為height[11],兩者都從1迭代(輸入從索引1開始賦值)。
比如:圖1第一行,從A10到A10,遍歷后,數(shù)值都為0,則當前的每列高度都為0,height[k]=0;從第二行開始,A9的元素就變?yōu)?,height[8]=1,實際的輸入case情況復雜,因此需要定義遍歷計算的規(guī)則。
按照上訴思路,構建兩層for循環(huán),外層i:10~1,內(nèi)層j:1-10。對于2×1的方塊,有兩種下落姿態(tài),水平和豎直放置下落。對于豎直下落而言,無論下方多么復雜,該方塊永遠都是直接落在過程中第一個看到的方塊。在迭代時,對于豎直下落方塊,每行直接對height加1即可。
對于水平放置方塊,情況比較復雜。首先方塊橫向是一個整體,下落位置受兩個子塊下方堆疊情況影響。作圖分析:
當前迭代列為j,首先考慮當前為1的方格(黑色),其構成的方塊的另一半,在其左側還是右側。如果在右側,右側的方塊子塊降落會由當前子塊決定,不用分析。如果在左側,那么當前子塊的落點取決于左側兄弟子塊的下方和當前列下方情況。自然的,如果左高右低,那么橫塊將搭在左側,右側子塊落點同左側。判斷條件為:if(height[j-1]>height[j]),實際調(diào)試時出錯,這塊分析不嚴謹。
實際情況如下:
由于當前子塊與左側子塊相連,迭代到當前列i時,左側子塊對應的height[j]已進行自加,實際條件應為:height[j-1]-1 > height[j]。也就是說,左側height減1后,與右側height大小,若左側大,height[j]=height[j-1]。否則height[j]自加。
由于對第i列迭代時,直接操作左右兩側的Ai和height[j-1],調(diào)試時發(fā)生數(shù)組索引越界異常。因此在循環(huán)內(nèi)部,首先處理兩種特殊情形:
程序簡化案例輸入過程,直接在主函數(shù)定義一個case數(shù)組,方法也直接寫在主函數(shù)中。
public class ExamSamsun { public static void main(String[] args) { // TODO Auto-generated method stub int[][] A={{0,0,0,0,0,0,0,0,0,0,0},{0,0,0,0,0,0,0,0,0,0,0},{0,0,0,0,0,0,0,0,0,0,0}, {0,0,0,0,1,0,0,0,1,1,0},{0,0,0,0,1,0,0,0,0,0,0},{0,1,1,0,0,0,0,0,0,0,0}, {0,0,0,0,0,1,1,0,0,0,0},{0,0,1,1,0,0,0,0,0,0,0},{0,0,0,0,0,0,0,0,1,0,0}, {0,0,0,0,0,0,0,0,1,0,0},{0,0,0,0,0,0,0,0,0,0,0}}; int[] height=new int[11]; //測試例結果應為1 1 2 2 1 2 1 1 0 3 0 0 for(int i=10;i>=1;i--) { for(int j=1;j<=10;j++) { if(A[i][j]==1) { //特殊情況 if(j==1&&A[i][j+1]==1) { if(height[j+1]>height[j]) height[j]=height[j+1]+1; else height[j]++; continue; //當前列已迭代完,執(zhí)行下列 } if(j==10&&A[i][j]==1) { if(height[j-1]-1>height[j]) height[j]=height[j-1]; else height[j]++; continue; } //一般情形 if(j>=2&&j<=9) { if(A[i][j-1]==1) { if(height[j-1]-1>height[j]) height[j]=height[j-1]; else height[j]++; continue; } if(A[i][j+1]==1) { if(height[j+1]>height[j]) height[j]=height[j+1]+1; else height[j]++; continue; } height[j]++; } } }//inner }//outer //output for(int i=1;i<=10;i++) System.out.print(height[i]+" "); } }
寫完后,又想了一遍,覺得對當前Ai=1的格子向前判斷似乎重復了,后續(xù)有空再簡化下程序。
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/73489.html
摘要:作用是將標準輸入中的所有大寫字母轉換為響應的小寫字母。的移植過的源代碼是在源代碼目錄下編譯的,所以源代碼目錄等于目標文件目錄,所以條件不滿足,將執(zhí)行分支的代碼。 ????????一個嵌入式產(chǎn)品的開發(fā)階段,需要不斷地把bootloader下載到存儲器中,如果存儲器使用nand flash,但是...
摘要:代表這個特性在標準中所處的一個狀態(tài)具體參照前文對的介紹對于這個特性,在全球中國所有瀏覽器中,分別有多少完全支持和部分支持,把兩部分值加起來,得到總份額。 困惑 相信大家都曾用caniuse網(wǎng)站查詢過css、js的一些兼容性問題,并且都從它反饋的兼容性數(shù)據(jù)中獲益,讓我們的線上項目更加穩(wěn)定、和諧的跑在用戶電腦里。不過對于caniuse頁面上的一些細節(jié),我們可能會感到困惑或者模棱兩可,今天就...
摘要:代表這個特性在標準中所處的一個狀態(tài)具體參照前文對的介紹對于這個特性,在全球中國所有瀏覽器中,分別有多少完全支持和部分支持,把兩部分值加起來,得到總份額。 困惑 相信大家都曾用caniuse網(wǎng)站查詢過css、js的一些兼容性問題,并且都從它反饋的兼容性數(shù)據(jù)中獲益,讓我們的線上項目更加穩(wěn)定、和諧的跑在用戶電腦里。不過對于caniuse頁面上的一些細節(jié),我們可能會感到困惑或者模棱兩可,今天就...
摘要:代表這個特性在標準中所處的一個狀態(tài)具體參照前文對的介紹對于這個特性,在全球中國所有瀏覽器中,分別有多少完全支持和部分支持,把兩部分值加起來,得到總份額。 困惑 相信大家都曾用caniuse網(wǎng)站查詢過css、js的一些兼容性問題,并且都從它反饋的兼容性數(shù)據(jù)中獲益,讓我們的線上項目更加穩(wěn)定、和諧的跑在用戶電腦里。不過對于caniuse頁面上的一些細節(jié),我們可能會感到困惑或者模棱兩可,今天就...
閱讀 1417·2021-11-24 09:39
閱讀 3698·2021-11-24 09:39
閱讀 1883·2021-11-16 11:54
閱讀 1473·2021-09-30 09:47
閱讀 1728·2021-09-26 10:16
閱讀 2355·2021-09-22 15:33
閱讀 1466·2021-09-14 18:01
閱讀 2453·2021-09-07 09:59