// 题目:统计一个数字在排序数组中出现的次数。

//  比如:排序数组{1。2,3,3,3,3,4。5}和数字3,因为3出现了4次。因此输出4

有一种最简单的算法,遍历。可是有比它效率更高的

先看遍历:

#include <stdio.h>
#include <assert.h> int num_time(int *arr, int len, int a)
{
int i = 0;
int count = 0;
assert(arr != NULL);
for (; i < len; ++i)
{
if (arr[i] == a)
count++;
}
return count;
} int main()
{
int arr[] = { 1, 2, 3, 3, 3, 3, 4, 5 };
int len = sizeof(arr) / sizeof(arr[0]);
printf("%d\n", num_time(arr, len, 3));
return 0;
}

另一种利用二分查找:

#include <stdio.h>

int GetFirstKey(int arr[], int left, int right, int len, int key)
{
int mid;
if (left > right)
{
return -1;
}
mid = left - (left - right) / 2;
if (key == arr[mid])
{
if ((mid > 0 && arr[mid - 1] != key) || mid == 0)
{
return mid;
}
else
{
right = mid - 1;
}
}
else if (arr[mid] < key)
{
left = mid + 1;
}
else
{
right = mid - 1;
}
return GetFirstKey(arr, left, right, len, key);
} int GetLastKey(int arr[], int left, int right, int len, int key)
{
int mid;
if (left > right)
{
return -1;
}
mid = left - (left - right) / 2;
if (key == arr[mid])
{
if ((mid < len - 1 && arr[mid + 1] != key || mid == len - 1))
{
return mid;
}
else
{
left = mid + 1;
}
}
else if (arr[mid] < key)
{
left = mid + 1;
}
else
{
right = mid - 1;
}
return GetLastKey(arr, left, right, len, key);
} int main()
{
int brr[] = { 1, 2, 3, 3, 3, 3, 4, 5};
int len = sizeof(brr) / sizeof(brr[0]);
int first = GetFirstKey(brr, 0, len - 1, len - 1, 3);
int last = GetLastKey(brr, 0, len - 1, len - 1, 3);
printf("%d\n", last - first + 1);
return 0;
}

最新文章

  1. ZK listbox 两种分页使用及比较
  2. 使用命令行执行webpagetest进行测试
  3. HiveServer2 的jdbc方式创建udf的修改(add jar 最好不要使用),否则会造成异常: java.sql.SQLException: Error while processing statement: null
  4. CDN技术分享
  5. HSSF,XSSF和SXSSF的区别
  6. 【web性能】 JS、CSS的合并、压缩、缓存管理
  7. 浅谈C语言中的联合体
  8. 得到某个进程所有线程ID和入口地址
  9. Android 判断wifi和4G网络是否开启
  10. [Git]更新远程代码到本地仓库
  11. Java IO详解(一)------字节输入输出流
  12. #Laravel 笔记# 多语言化 App::setLocale() 持久化。
  13. pb9常见错误及含义
  14. ArrayList源码学习----JDK1.7
  15. Doctype知识点总结
  16. DW1000 用户手册中文版 第5章 媒体访问控制(帧过滤)
  17. this全解js
  18. vue--js里跳转页面
  19. 区间修改区间求和cdq分治
  20. 初识GetMapping(&quot;&quot;),使用方法

热门文章

  1. Eureka 整理
  2. clusterdb - 对一个PostgreSQL数据库进行建簇
  3. 第一天 初识Python
  4. Win7 与win10绘制桌面壁纸的区别
  5. OneinStack 安装 LNMP 切换PHP版本
  6. react之webpack
  7. UML系统建模学习
  8. HashMap、ConcurrentHashMap以及HashTable(面试向)
  9. linux虚拟环境搭建
  10. SQL-如何使用 MongoDB和PyMongo。