




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、 2022年騰訊面試題(后臺開發(fā)崗位)第1題: 一、不定項選擇 將一組無序的數(shù)據(jù)重新排列成有序序列,其方法有() A 拓?fù)渑判?B 快速排序 C 堆排序 D 基數(shù)排序 答案:BCD 解析:在圖論中,由一個有向無環(huán)圖的頂點組成的序列,當(dāng)且僅當(dāng)滿意下列條件時,稱為該圖的一個拓?fù)渑判颍ㄓ⒄Z:Topological sorting)。 每個頂點消失且只消失一次;若A在序列中排在B的前面,則在圖中不存在從B到A的路徑。也可以定義為:拓?fù)渑判蚴菍τ邢驘o環(huán)圖的頂點的一種排序,它使得假如存在一條從頂點A到頂點B的路徑,那么在排序中B消失在A的后面 第2題: 某服務(wù)懇求經(jīng)負(fù)載均衡設(shè)備安排到集群A、B、C、D進(jìn)行
2、處理響應(yīng)的概率分別是10%、20%、30%和40%。已知測試集群所得的穩(wěn)定性指標(biāo)分別是90%、95%、99%和99.9%?,F(xiàn)在該服務(wù)器懇求處理失敗,且已排解穩(wěn)定性以外的問題,那么最有可能在處理該服務(wù)懇求的集群是_。 A、A B、B C、C D、D 答案:A B 解析:選中該集群,并且處理失敗了的概率為:10%*10%、20%*5%、30%*1%、40%*0.1%。A與B的概率最高。 第3題: 下列說法正確的有( ) A 環(huán)境變量可在編譯source code時指定 B 在編譯程序時,所能指定的環(huán)境變量不包括class path C javac一次可同時編譯數(shù)個Java源文件 D javac.e
3、xe能指定編譯結(jié)果要置于哪個名目(directory) 答案:A C D 第4題: 下列說法錯誤的有( ) A 數(shù)組是一種對象 B 數(shù)組屬于一種原生類 C int number=31,23,33,43,35,63 D 數(shù)組的大小可以任意轉(zhuǎn)變 答案:B C D 解答:Java把數(shù)組當(dāng)作一個java類來處理 java是純面對對象的語言,他的數(shù)組也是一個對象。 第5題: 下列說法錯誤的有( ) A 能被java.exe勝利運行的java class文件必需有main()方法 B J2SDK就是Java API C Appletviewer.exe可利用jar選項運行.jar文件 D 能被Applet
4、viewer勝利運行的java class文件必需有main()方法 答案:B C D 解析如下: B選項中J2SDK是編程工具,不是API. C選項中 Appletviewer.exe 就是用來解釋執(zhí)行java applet應(yīng)用程序的,簡潔理解就是沒有main函數(shù)的繼承applet類的java類。 D選項中 能被Appletviewer勝利運行的java class文件沒有main()方法 第6題: 卡方分布的方差為2倍的自由度為? A n B 1 C 2n D 4n 答案:C 注解: 分布的均值為自由度 n,記為 E() = n。 分布的方差為2倍的自由度(2n),記為 D() = 2n。
5、 第7題: 如何削減換頁錯誤? A 進(jìn)程傾向于占用CPU B 訪問局部性(localityofreference)滿意進(jìn)程要求 C 進(jìn)程傾向于占用I/O D 使用基于最短剩余時間(shortestremainingtime)的調(diào)度機(jī)制 答案:B 解析如下: 換頁錯誤又稱缺頁錯誤,當(dāng)一個程序試圖訪問沒有映射到物理內(nèi)存的地方時,就會消失缺頁錯誤, 這時操作系統(tǒng)就要去虛擬內(nèi)存中加載這塊內(nèi)存頁。 百度了一下,削減換頁錯誤的方法,即降低缺頁中斷率: 1、內(nèi)存頁框數(shù)。增加作業(yè)分得的內(nèi)存塊數(shù)。2、頁面大小。頁面劃分越大,中斷率越低。3、替換算法的優(yōu)劣影響缺頁中斷次數(shù)4、程序局部性。程序局部性好可削減缺頁中斷
6、(為什么?)。 那么B是對的,而對于D,最短剩余時間調(diào)度是CPU調(diào)度就緒進(jìn)程的方式,與頁面置換算法無關(guān),不要搞混淆了。 第8題: Please choose the right statement about constusage: A const int a; /const integer B int const a; /const integer C int const *a; /a pointer which point to const integer D const int *a; /a const pointer which point to integer E int const
7、 *a; / a const pointer which point to integer 答案:ABC 解析如下: 對于A和B,int const 和 const int 可以顛倒位置,意義不變 CDE都表示指向const int 的指針,而int *const a 才表示指向int的const指針 第9題: 下列定義語句中,錯誤的是 A int px*; B char*acp10; C char(*pac)10; D int(*p)(); 答案:A 第10題: 對類成員訪問權(quán)限的掌握,是通過設(shè)置成員的訪問掌握屬性實現(xiàn)的,下列不是訪問掌握屬性的是() A 公有類型 B 私有類型 C 愛護(hù)類型
8、 D 友元類型 答案:D 解析如下: C+中有三種權(quán)限掌握類型,分別是共有類型public,私有類型private,愛護(hù)類型protected. 友元是聲明一個類外的方法具有類方法同樣的訪問權(quán)限,目的是讓類外的方法可以訪問類內(nèi)部的屬性,不是訪問掌握屬性。 第11題: 給出以下定義,下列哪些操作是合法的? const char *p1 = “hello”; char *const p2 = “world”; A p1+; B p12 = w; C p22 = l; D p2+; 答案:A 解析如下: p1是指向字符常量的指針,p1本身不是常量,所以p1+合法,A正確。 p2本身是指針常量,可以指
9、向特別量的字符。但是hello這樣聲明的字符串是存儲在只讀存儲區(qū)的,不行修改,所以B,C,D都錯誤。 第12題: 以下集合對象中哪幾個是線程平安的?( ) A ArrayList B Vector C Hashtable D Stack 答案:BCD 解析如下: 在集合框架中,有些類是線程平安的,這些都是jdk1.1中的消失的。在jdk1.2之后,就消失許很多多非線程平安的類。 下面是這些線程平安的同步的類: vector:就比arraylist多了個同步化機(jī)制(線程平安),由于效率較低,現(xiàn)在已經(jīng)不太建議使用。在web應(yīng)用中,特殊是前臺頁面,往往效率(頁面響應(yīng)速度)是優(yōu)先考慮的。 statck
10、:堆棧類,先進(jìn)后出 hashtable:就比hashmap多了個線程平安 enumeration:枚舉,相當(dāng)于迭代器 除了這些之外,其他的都是非線程平安的類和接口。 第13題: 若下列所用變量均已經(jīng)正確定義,一下表達(dá)式中不合法的是 A x3 B +j C a=xy?x:y D x%=4 答案:B 解析如下: A ,x右移三位 B,+j是j自增1,+j是不合法的,編譯出錯 C,這是一個三目運算符,(exp1)?(exp2):(exp3) 當(dāng)exp1為true時個表達(dá)式結(jié)果為exp2 當(dāng)exp1為false時整個表達(dá)式結(jié)果為exp3 D,取余運算,等價于x=x%4 第14題: test.c文件中包
11、括如下語句: #define INT_PTR int* typedef int* int_ptr; INT_PTR a,b; int_ptr c,d; 文件中定義的四個變量中,哪個變量類型不是指針類型? A a B b C c D d E 都是指針 F 都不是指針 答案:B 解析如下: #define INT_PTR int* 這是宏定義,編譯預(yù)處理階段要進(jìn)行宏替換,INT_PTR a,b會變成 int* a,b 所以b不是指針類型typedef int* int_ptr; 這是自定義類型,也就是把int_ptr定義為 int型指針,編譯階段會把c,d都識別為指針 第15題: 不屬于馮諾依曼體
12、系結(jié)構(gòu)必要組成部分是: A CPU B Cache C RAM D ROM 答案:B 第16題: 二、問答題 有1000億條記錄,每條記錄由url,ip,時間組成,設(shè)計一個系統(tǒng)能夠快速查詢以下內(nèi)容 1.給定url和時間段(精確到分鐘)統(tǒng)計url的訪問次數(shù)2.給定ip和時間段(精確到分鐘)統(tǒng)計ip的訪問次數(shù) 答:首先,1000億條記錄全部放到內(nèi)存確定不夠,那就是分成小文件了,然后整合; 公共的時間段,由于精確到分鐘,我們把這每一分鐘建成一個小文件,每個小文件確定會有很多重復(fù)的ip,url;現(xiàn)在統(tǒng)計每個小的文件中url的訪問量和ip的訪問次數(shù),方法就是建立索引;(建立索引的目的是為了削減查詢次數(shù),
13、但是隨著索引級數(shù)增多也會造成花更多的時間在建立索引上);建立url的索引,假如是./question,可以分別給.和question建立索引,那么來了一條url,先看一級索引是不是匹配,匹配再看二級索引,相同的話就是我們要的url目標(biāo);ip的索引也是一樣,ip分成4段建立索引;所以這里影響效率的就是在索引建立這塊,索引建立好那就是查詢的事了的,就會變得特別快。假定給定了某個時間段,找出url的訪問量,那么先找到給定的時間段,對應(yīng)著剛開頭分割的小的文件(每一個分鐘)中搜尋,通過索引找到相同的url之后,開頭統(tǒng)計,直到搜尋完全部的給定時間段內(nèi)的全部的小的文件;求ip的訪問次數(shù)也是一樣,根據(jù)給定的時
14、間段,找到對應(yīng)的小的文件,通過索引找到相同的ip后統(tǒng)計,直到搜尋完了給定時間段內(nèi)的全部的小的文件。 第17題: 實現(xiàn)一個簡化的搜尋提示系統(tǒng)。給定一個包含了用戶query的日志文件,對于輸入的任意一個字符串s,輸出以s為前綴的在日志中消失頻率最高的前10條query。 由于是分布式系統(tǒng),假設(shè)至少有26臺機(jī)器,每個機(jī)器存儲以26個字母開頭的query日志文件(如機(jī)器1存的是a字母開頭的,機(jī)器2存的是以b字母開頭的) 每個機(jī)器上維護(hù)著一張哈希表,對于每條query, 在哈希表表中存放其地址(哈希地址為鏈?zhǔn)降模?,并對其進(jìn)行排序,按頻率由高到低進(jìn)行排序。 當(dāng)用戶進(jìn)行搜尋時,可以很快定位到某臺機(jī)器,并依據(jù)
15、哈希表,返回消失頻率最高的前10條query。 提示: 1、可以預(yù)處理日志 2、假設(shè)query不超過10億條,每個query不超過50字節(jié)。 3、考慮在大查詢量的狀況下如何實現(xiàn)分布式服務(wù) 系統(tǒng)前臺: 用JS監(jiān)控input輸入框的內(nèi)容變化,用戶輸入或者刪除字符(輸入串的發(fā)生變化)就觸發(fā)異步Javascript提交輸入內(nèi)容到后臺,引發(fā)后臺查詢。然后再講查詢結(jié)果消失頻率最高的前10條query呈現(xiàn)給用戶提示。 系統(tǒng)后臺: 首先有26臺服務(wù)器分別存儲26個字母開頭的query。所以首先要設(shè)計一個接收用戶懇求的服務(wù)器,這臺服務(wù)器可以依據(jù)用戶懇求的首字母將查詢懇求分發(fā)給對應(yīng)26臺服務(wù)器中的一個(相當(dāng)于查詢
16、懇求的路由功能)。 然后就是這26臺查詢服務(wù)器如何設(shè)計的問題了。 假設(shè)query不超過10億條,每個query不超過50字節(jié)。也就是query文件不超過50G,分在26臺機(jī)器上也就是每臺機(jī)器上的query文件不超過2G。 每個機(jī)器上維護(hù)著一張哈希表,對于每條query, 在哈希表表中存放其地址。收到每個query做hash運算可以找到query對應(yīng)的地址。對應(yīng)每個query存儲兩項信息,即query本身和被查詢次數(shù),也就是類似query:times這樣的存儲格式。 下面做預(yù)處理:26臺機(jī)器都對自身存儲的query進(jìn)行遍歷,分別找出a到z開頭query消失頻率最高的top10,這樣的查詢一次遍歷
17、就能找到,時間簡單度為O(N)。然后對找到的top10在內(nèi)存中構(gòu)建一個最小堆。其他非top10的query無需做排序處理。到這里預(yù)處理完成。 然后說查詢過程,查詢分為兩類, 1,以給出搜尋提示的異步Javascript提交的查詢,這種查詢直接返回最小堆中的10個query詞條即可。 2,用戶最終提交的查詢(即用戶輸入完畢點擊搜尋按鈕提交的查詢),這種查詢的query是用戶最終查詢的詞條,這樣的查詢應(yīng)當(dāng)引起后臺存儲的對應(yīng)query頻率的變化。當(dāng)一個query到達(dá)的時候,先用hash運算找到他的位置和對應(yīng)的頻率,hash操作時間簡單度是O(1),然后對應(yīng)的次數(shù)+1,然后用這個+1的次數(shù)與最小堆中首
18、個元素比較,假如大于最小堆首個元素,與最小堆中首個元素交換,然后最小堆做更新操作,保證最小堆的特性。否則不操作。這樣最小堆中維護(hù)的10個query始終是這臺機(jī)器上頻率最高的,查詢時返回這10個query詞條即可。 第18題: 小米公司內(nèi)部每個員工都會有一個專屬的工作郵箱,郵箱的前綴是員工姓名的拼音全拼,例如張強(qiáng)的郵箱是zhangqiang,但同時公司里有許多同名的人,為了避開大家相互之間發(fā)錯郵件,工程師們想了個規(guī)章來解決這個問題,即在這些同命人中,入職最早的郵箱前綴為姓名的拼音全拼,其次個入職的郵箱前綴為姓名的拼音全拼后面加“_a”,第三個入職的為姓名的拼音全拼后面加“_b”,以次類推,請按這個規(guī)章,假如公司里同時有3位名叫張強(qiáng)的員工,則他們的郵箱分別是zhangqiang,zhangqiang_a,zhangqiang_b.郵箱前綴是員工在公司里的重要標(biāo)識之一,問題來了:現(xiàn)在小米要進(jìn)行一次全員野外拉練活動,要求全部員工必需排成一隊出去,并且,有的員工要求他必需排在某人的前面或后面,作為組織者的你,收到
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 設(shè)定明確的工作優(yōu)先級計劃
- 財務(wù)分析在企業(yè)評估中的應(yīng)用計劃
- 教學(xué)創(chuàng)新與成果分享機(jī)制計劃
- 防止職業(yè)倦怠的小技巧計劃
- 醫(yī)學(xué)影像科醫(yī)生工作計劃
- 建立員工反饋與建議機(jī)制計劃
- 2025年電動晾衣機(jī)項目合作計劃書
- 景區(qū)承包合同
- 珠寶定制服務(wù)特殊條款協(xié)議
- 農(nóng)產(chǎn)品電商項目開發(fā)合作框架協(xié)議
- 五年級數(shù)學(xué)(小數(shù)乘除法)計算題專項練習(xí)及答案匯編
- 上海市楊浦區(qū)2024-2025學(xué)年八年級上學(xué)期英語期末考卷(含筆試答案無聽力答案、原文及音頻)
- 課題申報參考:法國漢學(xué)家弗朗索瓦·朱利安對中國山水畫論的闡釋研究
- 生物-山東省濰坊市、臨沂市2024-2025學(xué)年度2025屆高三上學(xué)期期末質(zhì)量檢測試題和答案
- 2024年09月2024年中國農(nóng)業(yè)發(fā)展銀行總行部門秋季校園招聘(22人)筆試歷年參考題庫附帶答案詳解
- 2025年小學(xué)督導(dǎo)工作計劃
- 2024-2025學(xué)年部編版歷史九年級上冊期末復(fù)習(xí)練習(xí)題(含答案)
- 2025年北京生命科技研究院招聘筆試參考題庫含答案解析
- 銀行金融機(jī)構(gòu)銀行金融服務(wù)協(xié)議
- 基于ChatGPT的ESG評級體系實現(xiàn)機(jī)制研究
- 2024年長沙民政職業(yè)技術(shù)學(xué)院單招職業(yè)技能測試題庫及答案解析
評論
0/150
提交評論