关注
把阿里内推时做的那题做了一便,该写的坑还是得填。。 // 自己的写的,不一定对,但是能过给的样例。 // 主要思路就是 深度搜索,终止条件就是 不能再加组合时,和best对比。 #include <iostream> #include <string> #include <sstream> using namespace std; int bom[9][10]; int product[10]; int cnt[10]; int res_count[10]; int res_sum = 0; int zero_count = 0; int n,m; char c ; void isbest(){ int tmp_count = 0; int sum = 0; for(int i =0; i <m;i++){ if(product[i] == 0){ tmp_count ++; } sum += product[i]; } if(tmp_count>zero_count ||(tmp_count == zero_count&&sum< res_sum)){ zero_count = tmp_count; for(int i =0; i < m;i++){ res_count[i] = cnt[i]; } res_sum = sum; } } // m 为组合数量 void dfs(int m){ for(int i =0; i < m;i++){ if(product[i] <0) return; } isbest(); for(int i = 0; i < m;i++){ cnt[i]++; // 使用组合i for(int j = 0;j < m;j++){ product[j] -= bom[i][j]; } dfs(m); // 回滚组合i for(int j = 0;j < m;j++){ product[j] += bom[i][j]; } cnt[i]--; } } int main(){ // m 为组合数, n为商品数目 cin >>n>>c>>m; // 读取商品数量 for(int i = 0 ; i < n;i++){ if(i <n-1){ cin >> product[i]; cin >> c; }else if(i == n-1) { cin >> product[i]; } } cin.ignore(); //读取组合 string s; stringstream str; for(int i = 0; i < m;i++){ getline(cin,s,'\n'); int pos = s.find(","); int start = 0; int n_copy = 0; while(n_copy<n+1){ if(n_copy >0&n_copy < n){ str << s.substr(start,pos-start) <<endl; str>>bom[i][n_copy-1]; str.str(""); }else if(n_copy == n){ str << s.substr(start,s.size()-start)<<endl; str>>bom[i][n_copy-1]; str.str(""); } start = pos+1; pos = s.find(",",start); n_copy++; } } dfs(m); for(int i =0; i<m;i++) { if(res_count[i] != 0) cout << "bom" <<i+1 <<"*"<< res_count[i]<<endl; } return 0; }
查看原帖
点赞 评论
相关推荐
查看28道真题和解析 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 实习的你做了哪些离谱的工作 #
3674次浏览 58人参与
# 工作压力大,你会干什么? #
3246次浏览 89人参与
# MiniMax求职进展汇总 #
1401次浏览 25人参与
# 参加哪些竞赛对找工作有帮助? #
3655次浏览 72人参与
# 邪修省钱套路 #
2594次浏览 102人参与
# 我的付费上班经历 #
5681次浏览 103人参与
# 找实习记录 #
7999次浏览 147人参与
# AI让你的思考变深了还是变浅了? #
1107次浏览 36人参与
# 如果不上班,你会去做什么 #
2366次浏览 85人参与
# 为了入行xx岗,我学了__ #
1938次浏览 34人参与
# 简历第一个项目做什么 #
2018次浏览 45人参与
# 你找工作的时候用AI吗? #
167468次浏览 868人参与
# 如何排解工作中的焦虑 #
257861次浏览 2383人参与
# 毕业论文进行时 #
24868次浏览 146人参与
# 大厂面试初体验 #
86607次浏览 398人参与
# 机械人的薪资开到多少,才适合去? #
159512次浏览 560人参与
# 你们的毕业论文什么进度了 #
1236208次浏览 9925人参与
# 你觉得面试是靠实力还是靠运气 #
27556次浏览 313人参与
# 毕业旅行去哪玩儿 #
21861次浏览 148人参与
# 硬件人秋招进展 #
265563次浏览 3971人参与
# 职场新人体验 #
160791次浏览 1149人参与

