【问题描述】最近超市要准备促销活动,为增加销量,超市决定将两种商品进行捆绑销售。现在需要你在已有的购物清单中找出来哪两种商品同时出现的次数最多。
【输入形式】第一行输入一个数N (1<=N<=100) ,表示现有购物清单的数量;随后的N行分别输入每个客户购买的商品(商品数固定为5),商品用大写字母表示。
【输出形式】输出需要捆鄉销售的两个商品。(按照ASCLL码的升序进行排列)
c++找出同时出现的次数最多的两个字母
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
4条回答 默认 最新
- |__WhoAmI__| 2022-12-14 22:27关注
#include <iostream> #include <cstring> #include <algorithm> using namespace std; const int MAX_N = 100; const int MAX_K = 5; int n; // Quantity of shopping lists char items[MAX_N][MAX_K]; // Shopping lists int counts[26][26]; // Counts of each pair of items int main() { // Read input cin >> n; for (int i = 0; i < n; i++) for (int j = 0; j < MAX_K; j++) cin >> items[i][j]; // Count occurrences of each pair of items memset(counts, 0, sizeof(counts)); for (int i = 0; i < n; i++) for (int j = 0; j < MAX_K; j++) for (int k = j + 1; k < MAX_K; k++) counts[items[i][j] - 'A'][items[i][k] - 'A']++; // Find most frequent pair of items int max_count = 0; char item1 = 'A', item2 = 'B'; for (int i = 0; i < 26; i++) for (int j = i + 1; j < 26; j++) if (counts[i][j] > max_count) { max_count = counts[i][j]; item1 = i + 'A'; item2 = j + 'A'; } // Output result cout << item1 << item2 << endl; return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 2无用
悬赏问题
- ¥15 关于#java#的问题:找一份能快速看完mooc视频的代码
- ¥15 这种微信登录授权 谁可以做啊
- ¥15 请问我该如何添加自己的数据去运行蚁群算法代码
- ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”
- ¥15 网络设备配置与管理这个该怎么弄
- ¥20 机器学习能否像多层线性模型一样处理嵌套数据
- ¥20 西门子S7-Graph,S7-300,梯形图
- ¥50 用易语言http 访问不了网页
- ¥50 safari浏览器fetch提交数据后数据丢失问题
- ¥15 matlab不知道怎么改,求解答!!