鱼C论坛

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

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

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

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

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

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

    }
    sort(ans.begin(),ans.end());
    return ans;
}

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

    }
    sort(a.begin(),a.end());//还要排序
    for(auto i:a)
    {
        cout<<i<<endl;
    }
 }
紫书上的一道题目
最佳答案
2023-11-6 21:07:09
以下是修改过的代码:
#include <iostream>#include <vector>#include <map>#include <algorithm>using namespace std;// 先将单词初始化,变成小写,然后进行排序string repr(const string& s) {    string ans = s;    for (int i = 0; i < ans.size(); i++) {        ans[i] = tolower(ans[i]);    }    sort(ans.begin(), ans.end());    return ans;}int main() {    int n = 0;    string s;    vector<string> words;    map<string, int> cnt;    while (cin >> s) {        if (s[0] == '#')            break;        words.push_back(s); // 保留原来的字符串        string t = repr(s);        if (!cnt.count(t))            cnt[t] = 0; // 如果没有查找到了,将其默认为0        cnt[t]++;    }    vector<string> a;    for (int i = 0; i < words.size(); i++) {        if (cnt[repr(words[i])] == 1)            a.push_back(words[i]);    }    sort(a.begin(), a.end()); // 还要排序    for (auto i : a) {        cout << i << endl;    }    return 0;}
这个程序的功能是从标准输入中读取单词,并按照一定规则进行处理和排序后输出。它使用了vector存储单词,使用map来统计每个单词的出现次数,使用sort函数对结果进行排序。

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

球一个最佳答案谢谢啦!这对我非常重要!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

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

如果想要保证有输出,可以在输入的单词中加入以"#"开头的单词,或者修改代码,在while循环结束后添加一个判断,如果没有输出的单词,则输出一个提示信息。例如:
if(a.empty()) {
    cout << "没有只出现一次的单词" << endl;
} else {
    for(auto i:a) {
        cout << i << endl;
    }
}

这样就可以在没有只出现一次的单词时输出提示信息。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-11-6 21:07:09 | 显示全部楼层    本楼为最佳答案   
以下是修改过的代码:
#include <iostream>#include <vector>#include <map>#include <algorithm>using namespace std;// 先将单词初始化,变成小写,然后进行排序string repr(const string& s) {    string ans = s;    for (int i = 0; i < ans.size(); i++) {        ans[i] = tolower(ans[i]);    }    sort(ans.begin(), ans.end());    return ans;}int main() {    int n = 0;    string s;    vector<string> words;    map<string, int> cnt;    while (cin >> s) {        if (s[0] == '#')            break;        words.push_back(s); // 保留原来的字符串        string t = repr(s);        if (!cnt.count(t))            cnt[t] = 0; // 如果没有查找到了,将其默认为0        cnt[t]++;    }    vector<string> a;    for (int i = 0; i < words.size(); i++) {        if (cnt[repr(words[i])] == 1)            a.push_back(words[i]);    }    sort(a.begin(), a.end()); // 还要排序    for (auto i : a) {        cout << i << endl;    }    return 0;}
这个程序的功能是从标准输入中读取单词,并按照一定规则进行处理和排序后输出。它使用了vector存储单词,使用map来统计每个单词的出现次数,使用sort函数对结果进行排序。

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

球一个最佳答案谢谢啦!这对我非常重要!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-23 23:26

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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