4----算法的效率评估4----算法的效率评估4----算法的效率评估


大O表示法同样适用于表示算法的空间复杂度。


4----算法的效率评估4----算法的效率评估  



空间换时间的典型算法:桶排序法。

常见算法如下:

#include <stdio.h>

/*
    问题:
    在一个由自然数1-1000中某些数字所组成的数组中,每个数字可能出现零次或者多次。
    设计一个算法,找出出现次数最多的数字。
*/

void search(int a[], int len)
{
    int sp[1000] = {0};
    int i = 0;
    int max = 0;
   
    for(i=0; i<len; i++)
    {
        int index = a[i] - 1;
       
        sp[index]++;
    }
   
    for(i=0; i<1000; i++)
    {
        if( max < sp[i] )
        {
            max = sp[i];
        }
    }
   
    for(i=0; i<1000; i++)
    {
        if( max == sp[i] )
        {
            printf("%d\n", i+1);
        }
    }
}

int main()
{
    int array[] = {1, 1, 3, 4, 5, 6, 6, 6, 2, 3};
   
    search(array, sizeof(array)/sizeof(*array));
   
    return 0;
}




相关文章:

  • 2021-11-17
  • 2021-07-09
  • 2022-01-18
  • 2022-02-15
  • 2021-06-21
  • 2022-12-23
  • 2021-07-05
  • 2021-07-18
猜你喜欢
  • 2021-11-28
  • 2022-01-10
  • 2021-07-20
  • 2022-01-16
  • 2021-07-14
  • 2021-04-26
  • 2022-12-23
相关资源
相似解决方案