清癯自安 2022-12-19 15:27 采纳率: 50%
浏览 159
已结题

C语言,将英文文本的单词统计,并输出最高频次的十个单词,我建立了链表,但是貌似排序出了问题

void Frequency(WORD *head)

{
int i;

WORD    *pre;

WORD    *p1;

WORD    *p2;

WORD    *end = NULL;

WORD    *p = head;

while(head->next != end)                  //冒泡排序
{
    p1 = head;
    pre = head;
    p2 = p1->next;
    if(p1->count < p2->count)             //先判断前两个单词频率
        {
            pre = p2;
            p1->next = p2->next;
            p2->next = p1;
        }
        else
            p1 = p1->next;
        p2 = p1->next;
    
    while(p1->next != end)                //把最小的一个排到最后
    {
        if(p1->count < p2->count)
        {
            pre->next = p2;
            p1->next = p2->next;
            p2->next = p1;
        }
        else
            p1 = p1->next;
        p2 = p1->next;
        pre = pre->next;
    }
    end = p1;                             //一次排序后,最后一个数已经最小,end往前移
}

for(i=0; i<10; i++)                       //输出频率前十的单词 
{
    printf("%s", head->word);
    printf("\n");
    head = head->next;
}

}

  • 写回答

6条回答 默认 最新

  • 快乐鹦鹉 2022-12-19 15:36
    关注

    20行之后应该加个head = p2,因为你改变了头结点了

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

报告相同问题?

问题事件

  • 系统已结题 12月27日
  • 已采纳回答 12月19日
  • 创建了问题 12月19日

悬赏问题

  • ¥15 Mac系统vs code使用phpstudy如何配置debug来调试php
  • ¥15 目前主流的音乐软件,像网易云音乐,QQ音乐他们的前端和后台部分是用的什么技术实现的?求解!
  • ¥60 pb数据库修改与连接
  • ¥15 spss统计中二分类变量和有序变量的相关性分析可以用kendall相关分析吗?
  • ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
  • ¥20 神经网络Sequential name=sequential, built=False
  • ¥16 Qphython 用xlrd读取excel报错
  • ¥15 单片机学习顺序问题!!
  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
  • ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)