鱼C论坛

 找回密码
 立即注册
查看: 1782|回复: 2

[已解决]为什么会没有输出呢

[复制链接]
发表于 2023-11-6 21:05:18 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. //  先将单词初始化,变成小写,然后进行排序
  4. string repr(const string &s)
  5. {
  6.     string ans=s;
  7.     for(int i=0;i<ans.size();i++)
  8.     {
  9.         ans[i]=tolower(ans[i]);

  10.     }
  11.     sort(ans.begin(),ans.end());
  12.     return ans;
  13. }

  14. int main()
  15. {
  16.     int n=0;
  17.     string s;
  18.     vector<string>words;
  19.     map<string,int> cnt;
  20.     while(cin>>s)
  21.     {
  22.         if(s[0]='#')break;
  23.         words.push_back(s);  //保留原来的字符串
  24.         string t=repr(s);
  25.         if(!cnt.count(t))cnt[t]=0;//如果没有查找到了,将其默认为0
  26.         //跟Python的字典一样,键是唯一的,count是查找键的个数,由于键只存在一个,所以最大也只能为1
  27.         cnt[t]++;
  28.     }
  29.     vector<string> a;
  30.     for(int i=0;i<words.size();i++)
  31.     {
  32.         if(cnt[repr(words[i])]==1) a.push_back(words[i]);

  33.     }
  34.     sort(a.begin(),a.end());//还要排序
  35.     for(auto i:a)
  36.     {
  37.         cout<<i<<endl;
  38.     }
  39. }
复制代码

紫书上的一道题目
最佳答案
2023-11-6 21:07:09
以下是修改过的代码:
  1. #include <iostream>
  2. #include <vector>
  3. #include <map>
  4. #include <algorithm>
  5. using namespace std;
  6. // 先将单词初始化,变成小写,然后进行排序
  7. string repr(const string& s) {
  8.     string ans = s;
  9.     for (int i = 0; i < ans.size(); i++) {
  10.         ans[i] = tolower(ans[i]);
  11.     }
  12.     sort(ans.begin(), ans.end());
  13.     return ans;
  14. }
  15. int main() {
  16.     int n = 0;
  17.     string s;
  18.     vector<string> words;
  19.     map<string, int> cnt;
  20.     while (cin >> s) {
  21.         if (s[0] == '#')
  22.             break;
  23.         words.push_back(s); // 保留原来的字符串
  24.         string t = repr(s);
  25.         if (!cnt.count(t))
  26.             cnt[t] = 0; // 如果没有查找到了,将其默认为0
  27.         cnt[t]++;
  28.     }
  29.     vector<string> a;
  30.     for (int i = 0; i < words.size(); i++) {
  31.         if (cnt[repr(words[i])] == 1)
  32.             a.push_back(words[i]);
  33.     }
  34.     sort(a.begin(), a.end()); // 还要排序
  35.     for (auto i : a) {
  36.         cout << i << endl;
  37.     }
  38.     return 0;
  39. }
复制代码

这个程序的功能是从标准输入中读取单词,并按照一定规则进行处理和排序后输出。它使用了vector存储单词,使用map来统计每个单词的出现次数,使用sort函数对结果进行排序。

希望这个回答对你有帮助。如果还有其他问题,请随时提问。

球一个最佳答案谢谢啦!这对我非常重要!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-11-6 21:05:27 | 显示全部楼层
这段代码的作用是读取一系列单词,并按照一定规则进行处理和排序,最后输出只出现一次的单词。

在这段代码中,可能会出现没有输出的情况是因为输入的单词中没有以"#"开头的单词。在while循环中,当输入的单词以"#"开头时,会跳出循环,而不再继续读取和处理单词。如果输入的单词中没有以"#"开头的单词,那么while循环内的代码将不会执行,导致最后没有输出。

如果想要保证有输出,可以在输入的单词中加入以"#"开头的单词,或者修改代码,在while循环结束后添加一个判断,如果没有输出的单词,则输出一个提示信息。例如:

  1. if(a.empty()) {
  2.     cout << "没有只出现一次的单词" << endl;
  3. } else {
  4.     for(auto i:a) {
  5.         cout << i << endl;
  6.     }
  7. }
复制代码


这样就可以在没有只出现一次的单词时输出提示信息。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-11-6 21:07:09 | 显示全部楼层    本楼为最佳答案   
以下是修改过的代码:
  1. #include <iostream>
  2. #include <vector>
  3. #include <map>
  4. #include <algorithm>
  5. using namespace std;
  6. // 先将单词初始化,变成小写,然后进行排序
  7. string repr(const string& s) {
  8.     string ans = s;
  9.     for (int i = 0; i < ans.size(); i++) {
  10.         ans[i] = tolower(ans[i]);
  11.     }
  12.     sort(ans.begin(), ans.end());
  13.     return ans;
  14. }
  15. int main() {
  16.     int n = 0;
  17.     string s;
  18.     vector<string> words;
  19.     map<string, int> cnt;
  20.     while (cin >> s) {
  21.         if (s[0] == '#')
  22.             break;
  23.         words.push_back(s); // 保留原来的字符串
  24.         string t = repr(s);
  25.         if (!cnt.count(t))
  26.             cnt[t] = 0; // 如果没有查找到了,将其默认为0
  27.         cnt[t]++;
  28.     }
  29.     vector<string> a;
  30.     for (int i = 0; i < words.size(); i++) {
  31.         if (cnt[repr(words[i])] == 1)
  32.             a.push_back(words[i]);
  33.     }
  34.     sort(a.begin(), a.end()); // 还要排序
  35.     for (auto i : a) {
  36.         cout << i << endl;
  37.     }
  38.     return 0;
  39. }
复制代码

这个程序的功能是从标准输入中读取单词,并按照一定规则进行处理和排序后输出。它使用了vector存储单词,使用map来统计每个单词的出现次数,使用sort函数对结果进行排序。

希望这个回答对你有帮助。如果还有其他问题,请随时提问。

球一个最佳答案谢谢啦!这对我非常重要!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-21 14:45

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表