清癯自安 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 在获取boss直聘的聊天的时候只能获取到前40条聊天数据
  • ¥20 关于URL获取的参数,无法执行二选一查询
  • ¥15 液位控制,当液位超过高限时常开触点59闭合,直到液位低于低限时,断开
  • ¥15 marlin编译错误,如何解决?
  • ¥15 有偿四位数,节约算法和扫描算法
  • ¥15 VUE项目怎么运行,系统打不开
  • ¥50 pointpillars等目标检测算法怎么融合注意力机制
  • ¥20 Vs code Mac系统 PHP Debug调试环境配置
  • ¥60 大一项目课,微信小程序
  • ¥15 求视频摘要youtube和ovp数据集