演算法微軟100題數字查詢
題:假設你有一個用1001個整陣列成的陣列,這些整數是任意排列的,但是你知道所有的整數都在1到1000(包括1000)之間。此外,除一個數字出現兩次外,其他所有數字只出現一次。假設你只能對這個陣列做一次處理,用一種演算法找出重複的那個數字。如果你在運算中使用了輔助的儲存方式,那麼你能找到不用這種方式的演算法嗎?
分析:
方法一、若使用輔助的儲存方式,該選擇何種儲存方式呢?可使用hash的儲存方式,以1到1000作為hash表的索引,遍歷原陣列,統計各數字出現的個數並儲存到以該數字為索引值的hash表中,若某個hash[x]的值為2則退出迴圈,x就是重複出現兩次的數字。時間複雜度最壞是O(n)。優點:高效率,缺點:消耗的記憶體空間過大。程式碼如下:
- int fun1(const int a[])
- {
- int hash[1002]={0};
- int x=0;
- for(int i = 0; i<1001; i++)
- {
- if((++hash[a[i]]) == 2)
- {
- x = a[i];
- break;
- }
- }
- return x;
- }
方法二、若不使用輔助的儲存方式呢?已知1001個整陣列成的陣列只有一個數字出現了兩次,且整數都在1到1000之間,所以可推得陣列裡麵包含了1到1000之間的所有數字為[1,2,3……1000]和一個出現兩次的x為1到1000中的任一個數字。這樣就可以計算原陣列裡的所有數字之和S1和等差數列[1,2,3……1000]的和S2,再計算S1與S2之差,該差就是原陣列中出現兩次的數字x。時間複雜度是固定的O(n)。優缺點:記憶體空間消耗幾乎沒有,但是效率要輸於使用hash表的儲存方式。程式碼如下:
- int fun2(const int a[])
- {
- int s1=0,s2;
- s2 = 1001*1000/2;
- for(int i = 0; i<1001; i++)
- {
- s1+=a[i];
- }
- return s1-s2;
- }
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29012686/viewspace-1147099/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 數字查詢統計重複
- 微軟面試題之數字謎題 (轉)微軟面試題
- 微軟面試100題微軟面試
- 微軟的100道演算法面試題(終結版)微軟演算法面試題
- 查詢演算法__插值查詢演算法
- 查詢演算法__二分查詢演算法
- 查詢演算法__Fibonacci查詢演算法
- 查詢演算法演算法
- 演算法 - 查詢演算法
- 演算法(查詢)演算法
- #查詢演算法#【1】簡單查詢:順序、折半查詢演算法
- 因數分解演算法、週期查詢演算法(簡化)演算法
- 查詢演算法之二分查詢演算法
- MYSQL練習題:給定數字的頻率查詢中位數(Leetcode困難)MySqlLeetCode
- 藍橋杯 演算法訓練 區間k大數查詢 (Java解題)演算法Java
- 每日一題10009-反轉數字每日一題
- 演算法題:刪除 K 位數字演算法
- Mysql 巢狀查詢100例子MySql巢狀
- 查詢演算法(上)演算法
- 查詢演算法(下)演算法
- Java 查詢演算法Java演算法
- 常用查詢演算法演算法
- 每日一題 - 劍指 Offer 53 - I. 在排序陣列中查詢數字 I每日一題排序陣列
- 每日一練(24):在排序陣列中查詢數字排序陣列
- MySQL查詢某個欄位含有字母數字的值MySql
- Java中查詢給定數字下最大素數的2種方法Java
- 二分查詢【折半查詢】演算法 PHP 版演算法PHP
- K大數查詢
- mysql查詢表列數MySql
- 開啟查詢慢查詢日誌引數
- 微軟等資料結構+演算法面試100題全部答案集錦微軟資料結構演算法面試
- 插值查詢演算法演算法
- 子字串查詢演算法字串演算法
- 雜湊查詢演算法演算法
- 線性查詢演算法演算法
- 常用查詢演算法 (轉)演算法
- 面試:Java 實現查詢旋轉陣列的最小數字面試Java陣列
- MySQL如何查詢某個欄位含有字母數字的值MySql