略懂c语言 2022-05-12 14:02 采纳率: 92.6%
浏览 81
已结题

老是报错,Python通过不了,需要c

题目如下:可以测试
http://acm.usx.edu.cn/aspnet/Question.aspx?qid=1263
代码


import re
 
T = int(input(''))
content = []
for i in range(T):
    txt = ''
    n = int(input(f''))
    for j in range(n):
        a = input(f'')
        txt += a
    content.append(txt)
 
for k in content:
    word = re.findall(r'\w+',k)
    word_dict = {i:word.count(i) for i in word}
    word_list = sorted(list(word_dict.items()), key=lambda x:x[0])
    word_list.sort(key=lambda x:x[1], reverse=True)
    for i,j in word_list:
        print(i,j)
  • 写回答

2条回答 默认 最新

  • 丨秋水丨 2022-05-12 19:11
    关注
    #include<iostream>
    #include<map>
    #include<string>
    #include<cctype>
    #include<vector>
    #include<algorithm>
    typedef std::pair<std::string, int> WordStat;
    typedef std::map<std::string, int>::iterator WordIterator;
    bool cmpfunc(const WordStat& l, const WordStat& r) {
        return l.second == r.second ? l.first < r.first : l.second > r.second;
    }
    int main()
    {
        int testNum;
        std::cin >> testNum;
        while (testNum--)
        {
            int lineNum;
            std::cin >> lineNum;
            std::cin.ignore();
            std::string line;
            std::map<std::string, int> wordMap;
            while (lineNum--)
            {
                std::getline(std::cin, line);
    
                std::string word = "";
                bool lastCharIsAlpha = 0;
                int i = 0;
                while (i < line.size())
                {
                    while (i < line.size() && !isalpha(line[i]))++i;
                    
                    word = "";
                    while (i < line.size() && isalpha(line[i]))
                    {
                        word += line[i];
                        ++i;
                    }
                    if (!word.empty())
                    {
                        wordMap[word]++;
                    }
                }
            }
            std::vector<WordStat>words;
            for (WordIterator iter = wordMap.begin(), iterEnd = wordMap.end(); iter != iterEnd; ++iter)
            {
                words.push_back(std::make_pair(iter->first, iter->second));
            }
            std::sort(words.begin(), words.end(), cmpfunc);
            for (int i = 0; i < words.size(); ++i)
            {
                std::cout << words[i].first << " " << words[i].second << std::endl;
            }
        }
        return 0;
    }
    

    已测试通过

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 5月20日
  • 已采纳回答 5月12日
  • 修改了问题 5月12日
  • 赞助了问题酬金5元 5月12日
  • 展开全部

悬赏问题

  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持