【2013年数据结构真题】


highlight: a11y-dark

41题

王道解析:

算法的策略是从前向后扫描数组元素,标记出一个可能成为主元素的元素Num 。然后重新计数,确认Num是否是主元素。算法可分为以下两步:

  • 选取候选的主元素:依次扫描所给数组中的每个整数, 将第一个遇到的整数Num保存到c中, 记录Num的出现次数为1; 若遇到的下一个整数仍等于Num, 则计数加1, 否则计数减1; 当计数减到0时, 将遇到的下一个整数保存到c中,计数重新记为1, 开始新一轮计数,即从当前位置开始重复上述过程, 直到扫描完全部数组元素。

  • 判断c中元素是否是真正的主元素:再次扫描该数组,统计c中元素出现的次数,若大于n/2, 则为主元素;否则, 序列中不存在主元素。

c++ 复制代码
int Majority(int A[], int n) {
    int i, c, count = 1; //c用来保存候选主元素,count用来计数
    c = A[0];  //设置A[O]为候选主元素
    for (i = 1; i < n; i++) //查找候选主元素
        if (A[i] == c)
            count++;//对A中的候选主元素计数
        else 
            if (count > 0) //处理不是候选主元素的情况
                count-- ;
            else {//更换候选主元素, 重新计数
                c = A[i];
                count = 1;
        }
    if (count > 0)
        for (i = count = 0; i < n; i++) //统计候选主元素的实际出现次数
            if (A[i] == c)
                count++;
    if (count > n / 2) return c; //确认候选主元素
    else return -1; //不存在主元素
}

最优解:

c++ 复制代码
int find(int A[],int n){
    QuickSort(A,0,n-1);//快速排序O(nlog2n)
    int k,max=0,count=1;
    for(int i=0;i<n-1;++i){
        if(A[i+1]==A[i]){
            count++;
        }else{
            if(count>max){
                max=count;
                k=A[i];
            }
            count=1;
        }   
    }
    if(max>n/2)
        return k;
    else
        return -1;
}

暴力解1

c++ 复制代码
int fun ( int A[], int n ) {
    int* B = (int*) malloc( sizeof (int) * n ) ;
    for ( int i = 0; i < n; ++i )
        B[i] = 0 ;
    int i, k ;
    int max = 0 ;
    for ( i = 0; i < n; ++i )
        if ( A[i] > 0 && A[i] <= n )
            B[A[i] - 1]++ ;
    for ( i = 0; i < n; ++i )
        if ( B[i] > max ) {
            max = B[i] ;
            k = i ;
        }
    if ( max > n / 2 )
        return k + 1 ;
    else
        return -1 ;
}

暴力解2:双层循环

  • 选择数组的每一个元素i
  • 统计i在整个数组出现的次数
  • 如果大于n/2则返回

题目要求我们查找是否存在主元素,那可以直接定义找到为1,没找到为0,并写好注释。既然要找某个数是否满足主元素的性质,那就每个数去检查是否为主元素,要检查每个元素,则需要遍历。

c++ 复制代码
int majority(int A[], n) {
    int m;
    //遍历每一个元素
    for (int i = 0; i < n; i++) {
    //由于每次遍历的元素 都是从0开始统计出现的次数m=0;
        for (int j = 0; j < n; j++)
            if (A[i] == A[j])
                m++;
            if (m > n / 2) { 
                //找到了主元素
                return A[m];
            }
        }
        //未找到主元素
        return -1;
}
相关推荐
搞科研的小刘选手7 分钟前
【大连市计算机学会主办】第三届图像处理、智能控制与计算机工程国际学术会议(IPICE 2026)
图像处理·人工智能·深度学习·算法·计算机·数据挖掘·智能控制
南境十里·墨染春水9 分钟前
数据结构 —— 顺序表
数据结构
人月神话-Lee10 分钟前
【图像处理】高斯模糊——最优雅的模糊算法
图像处理·人工智能·算法·ios·ai编程·swift
tongluowan00717 分钟前
数据结构 Bitmap(位图)示例 - 用户签到系统
开发语言·数据结构·bitmap·用户签到系统
洛水水19 分钟前
Redis对象类型与底层数据结构
数据结构·数据库·redis
大熊背22 分钟前
双目拼接竖缝消除(ISP 分区锐化实操方案) 优化方案
人工智能·算法·双目拼接
_日拱一卒25 分钟前
LeetCode:105从前序与中序遍历序列构造二叉树
算法·leetcode·职场和发展
MicroTech202525 分钟前
微算法科技(NASDAQ :MLGO)发布基于NEQR技术的新型量子视频处理算法,重构智能视觉底层逻辑
科技·算法·音视频
Hesionberger26 分钟前
LeetCode114:二叉树展开为链表(三解法)
数据结构
techdashen28 分钟前
Async Rust 近况补课:从 `async-trait` 到原生 async trait
网络·算法·rust