m0_58509014 2023-08-22 15:48 采纳率: 0%
浏览 4

王道数据结构顺序表课后题,请问这样的思路和代码有错吗?

img

王道数据结构顺序表课后题,请问这样的思路和代码有错吗,复习的时候写的和答案不一样也不知道对不对,写的很潦草大家见谅

  • 写回答

3条回答 默认 最新

  • qzjhjxj 2023-08-23 09:24
    关注

    你的思路有点问题,A[n] 数组 n 要设置很大的范围,才能实现计数的目的,不合理。修改如下,供参考:

    int Majority(seqlist* A)
    {
        int i, cnt, Num;
        if (A->length == 0)  return -1;
        if (A->length == 1)  return A->data[0];
        for (i = 1, cnt = 1, Num = A->data[0]; i < A->length; i++){
            if (A->data[i] == Num)  // 找到出现次数最多的元素记入 Num
                cnt++;
            else
                cnt--;
            if (cnt == 0) {
                Num = A->data[i];
                cnt = 1;
            }
        }
        for (i = 0, cnt = 0; i < A->length; i++) { // 判断 Num 是否是主元素
            if (A->data[i] == Num) cnt++;
            if (cnt > A->length / 2) return A->data[i];
        }
        return -1;
    }
    //复杂度:T(n) = O(n), S(n) = O(1)。
    
    
    评论

报告相同问题?

问题事件

  • 修改了问题 8月22日
  • 创建了问题 8月22日

悬赏问题

  • ¥15 java业务性能问题求解(sql,业务设计相关)
  • ¥15 52810 尾椎c三个a 写蓝牙地址
  • ¥15 elmos524.33 eeprom的读写问题
  • ¥15 使用Java milo连接Kepserver服务端报错?
  • ¥15 用ADS设计一款的射频功率放大器
  • ¥15 怎么求交点连线的理论解?
  • ¥20 软件开发方法学习来了
  • ¥15 微信小程序商城如何实现多商户收款 平台分润抽成
  • ¥15 HC32L176调试了一个通过TIMER5+DMA驱动WS2812B
  • ¥15 关于自相关函数法和周期图法实现对随机信号的功率谱估计的matlab程序运行的问题,请各位专家解答!