寒武紀演算法開發崗位二面手撕程式碼題目記錄
寒武紀演算法開發崗位二面手撕程式碼題目記錄
該程式碼是寒武紀的二面面試題:
題目:
給定一個陣列,求能組成的和中,最小不可能的和。
例如:[1,2,3,5],最小不可能的和為12。
#include<iostream> #include<vector> #include<string> #include<algorithm> using namespace std; int minNoSum(vector<int>& data) { int n = data.size(); if (n == 0) return 0; if (n == 1) return 1; int minv = INT_MAX; int sum = 0; sort(data.begin(), data.end()); for (int i = 0; i < n; ++i) { if (data[i] < minv) minv = data[i]; sum += data[i]; } // dp[i][j]表示前i個數,和為j是否能取到 vector<vector<bool>> dp(n, vector<bool>(sum+1, 0)); for (int num : data) { dp[0][num] = 1; } for (int i = 1; i < n; ++i) { for (int j = 1; j <= sum; ++j) { if (j >= data[i]) { dp[i][j] = dp[i-1][j] || dp[i-1][j-data[i]]; } else { dp[i][j] = dp[i - 1][j]; } } } for (int i = 1; i < sum; ++i) { if (!dp[n - 1][i]) return i; } return sum + 1; } int main() { vector<int> data = {1,2,4,5}; int res = minNoSum(data); cout << res << endl; system("pause"); return 0; }
相關文章
- 面試常見手撕程式碼題面試
- 記錄一次騰訊Go開發崗位面試經過Go面試
- 手撕面試題ThreadLocal!!!面試題thread
- 程式碼目錄結構記錄
- 騰訊技術崗位筆試&面試題(二)筆試面試題
- 『手撕Vue-CLI』獲取下載目錄Vue
- 《星辰牧歌》開發程式紀錄
- 面試演算法題記錄面試演算法
- 題目記錄
- 手撕Flutter開發Flutter
- 對於技術崗位而言,開發崗累還是演算法崗累呢?演算法
- 寒武紀財報: 2022年寒武紀營收7.29億元 同比增長1.11%營收
- 面試開發崗位,你應該知道的回答技巧!面試
- 前端工程師進階之旅-手撕程式碼【前端常用方法以及面試常見題】前端工程師面試
- 記錄一次測開面試題記錄面試題
- 前端面試-手撕程式碼篇前端面試
- 成都開手撕發具票
- 天津開手撕發具票
- SQL崗位30個面試題,SQL面試問題及答案SQL面試題
- LeetCode解題記錄(貪心演算法)(二)LeetCode演算法
- Linux程式開發中如何判斷目錄是否為根目錄?Linux
- 🐒編寫高質量程式碼(手撕程式碼)
- [ Java面試題 ]Java 開發崗面試知識點解析Java面試題
- 手撕面試官系列:BAT面試常問85題面試BAT
- 面試題目:手寫一個LRU演算法實現面試題演算法
- 深度學習高頻手撕程式碼深度學習
- 面試手撕(一):圖搜尋,排布問題面試
- Java面試題記錄第二天Java面試題
- 微信小程式開發記錄_01程式碼構成微信小程式
- 程式碼審計————目錄
- 關於太原開手撕發票
- 面試程式碼題(vivo)數位之積面試
- 面試題記錄面試題
- 【問題記錄】— web頁面呼叫本地程式Web
- 如何入行軟體開發——常見問題及崗位分工
- 寒武紀財報:2023年Q3寒武紀營業收入3134.28萬元 同比下降66.15%
- 微信小程式開發記錄_03_開發指南_小程式程式碼組成微信小程式
- 騰訊技術崗位筆試&面試題(一)筆試面試題