【C语言】经典题目(四) 2

简介: 【C语言】经典题目(四)

函数实现二分查找

首先我们需要自定义一个函数,在函数内需要对一个数组实现二分查找。
函数参数我们需要一个数,即我们的目标数,和一个数组首元素的地址

对于函数的返回值,因为我们不仅仅是想知道在数组中有没有目标数,更想明确它的下标,所以函数的返回值,我们不妨返回的是下标。若是没有找到的话,那就返回一个负数-1即可。(因为不会有数组元素的下标为负数的。)

然后我们在主函数中调用函数,传递参数即可。

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
int binary_search(int n, int arr[],int sz)
{
  int left = 0, right = sz-1;
  int mid = (left + right) / 2;
  while (left <= right)
  {
    if (arr[mid] == n)
      return mid;
    else if (arr[mid] > n)
    {
      right = mid - 1;//left不变
      mid = (left + right) / 2;
    }
    else
    {
      left = mid + 1;//right不变
      mid = (left + right) / 2;
    }
  }
  return  -1;
}
int main()
{
  int n = 0;
  int arr[10] = { 1,4,6,7,9,11,14,16,18,19 };
  printf("你想要查找的数字:\n");
  int sz = sizeof(arr) / sizeof(arr[0]);
  scanf("%d", &n);
  int ret = binary_search(n, arr,sz);
  if (ret>-1)
  {
    printf("找到了\n");
    printf("下标为%d", ret);
  }
  else
    printf("没找到\n");
  return 0;
}

运行结果:

写一个函数,没调用一次这个函数,就会将num的值增加1

因为每调用一次函数,就要将num的变化,而能使得num变化,我们需要向函数传递num的地址,使得每调用一次,就能使num的值发生变化。

代码实现:

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
void Add(int* p)
{
  *p = *p + 1;
}
int main()
{
  int num = 3;
  Add(&num);
  printf("%d\n", num);
  Add(&num);
  printf("%d\n", num);
  Add(&num);
  printf("%d\n", num);
  return 0;
}

相关文章
|
8月前
|
C语言
C语言:数组和指针笔试题解析(包括一些容易混淆的指针题目)
C语言:数组和指针笔试题解析(包括一些容易混淆的指针题目)
|
8月前
|
存储 C语言 C++
C语言------------指针笔试题目深度剖析
C语言------------指针笔试题目深度剖析
52 1
2.C语言题目---字符串左旋
2.C语言题目---字符串左旋
80 1
|
3月前
|
程序员 C语言
【C语言】LeetCode(力扣)上经典题目
【C语言】LeetCode(力扣)上经典题目
|
存储
1.C语言题目---指针类(基础)
1.C语言题目---指针类(基础)
68 1
|
5月前
|
存储 编译器 C语言
【C语言】指针练习题目
【C语言】指针练习题目
|
7月前
|
测试技术 C语言
数据结构学习记录——树习题—Tree Traversals Again(题目描述、输入输出示例、解题思路、解题方法C语言、解析)
数据结构学习记录——树习题—Tree Traversals Again(题目描述、输入输出示例、解题思路、解题方法C语言、解析)
53 1
|
8月前
|
算法 编译器 API
C语言易混淆、简单算法、结构体题目练习、常见关键字总结-1
C语言易混淆、简单算法、结构体题目练习、常见关键字总结
|
7月前
|
C语言
c语言循环题目
c语言循环题目
|
8月前
|
C语言
PTA 浙大版《C语言程序设计(第3版)》题目集 习题8-4 报数 (20分)
PTA 浙大版《C语言程序设计(第3版)》题目集 习题8-4 报数 (20分)