C/C++ 整数二分以及浮点数二分

个人主页:仍有未知等待探索_C语言疑难,数据结构,小项目-CSDN博客

专题分栏:算法_仍有未知等待探索的博客-CSDN博客

目录

一、引言

二、整数二分(二分查找)

1、步骤:

2、示例

【问题一】求第一个大于3的数的位置?

【问题二】求第一个大于等于3的数的位置?

【问题三】求最后一个小于等于3的数的位置?

【问题四】求最后一个小于3的位置?

三、浮点数二分


一、引言

二分说简单也简单,说难也难。简单在于思想非常的简单,难就难在边界值的确定上。下面我将进行解释。二分的前提是数组是有序的,这个大家应该都知道哈。

二、整数二分(二分查找)

1、步骤:

  1. 先找到数组的左边界 l 和右边界 r。
  2. 然后确定要查找的数x 和中间点 mid。
  3. if(mid < x)证明 x 在 mid 的右边,反之在其左边。
  4. 然后进行循环,直到 l > r的时候停止循环。

2、示例

对于给定一个数组【1,2,3,3,7,7,7,8,9】

【问题一】求第一个大于3的数的位置?

【问题二】求第一个大于3的数的位置?

【问题三】求最后一个小于等于3的数的位置?

【问题四】求最后一个小于3的位置?

其实这些问题大差不差,主要是注意一下查找数 x 和 中间数 mid 的关系

【问题一】求第一个大于3的数的位置?

cpp 复制代码
#include<stdio.h>
int q[] = { 1,2,3,3,7,7,7,8,9 }, k = 3;//k为查找的数
int Binary_search(int q[], int l, int r) {
	int i = l - 1, j = r + 1, mid;
	while (i+1 != j) 
	{
		mid = (i + j) >> 1;
		//分界点是小于等于k的在左边,大于k的在右边,所以直接返回 j 就是答案
		if (q[mid] <= k)
		{
			i = mid;
		}
		else
		{
			j = mid;
		}
	}
	return j;
}
int main() {
	
	int len = sizeof(q) / sizeof(q[0]);
	int res = Binary_search(q, 0, len - 1);

	printf("%d", res);
	return 0;
}

【问题二】求第一个大于等于3的数的位置?

cpp 复制代码
#include<stdio.h>
int q[] = { 1,2,3,3,7,7,7,8,9 }, k = 3;//k为查找的数
int Binary_search(int q[], int l, int r) {
	int i = l - 1, j = r + 1, mid;
	while (i+1 != j) 
	{
		mid = (i + j) >> 1;
		
		if (q[mid] < k)
		{
			i = mid;
		}
		else
		{
			j = mid;
		}
	}
	return j;
}
int main() {
	
	int len = sizeof(q) / sizeof(q[0]);
	int res = Binary_search(q, 0, len - 1);

	printf("%d", res);
	return 0;
}

【问题三】求最后一个小于等于3的数的位置?

cpp 复制代码
#include<stdio.h>
int q[] = { 1,2,3,3,7,7,7,8,9 }, k = 3;//k为查找的数
int Binary_search(int q[], int l, int r) {
	int i = l - 1, j = r + 1, mid;
	while (i+1 != j) 
	{
		mid = (i + j) >> 1;
		
		if (q[mid] <= k)
		{
			i = mid;
		}
		else
		{
			j = mid;
		}
	}
	return i;
}
int main() {
	
	int len = sizeof(q) / sizeof(q[0]);
	int res = Binary_search(q, 0, len - 1);

	printf("%d", res);
	return 0;
}

【问题四】求最后一个小于3的位置?

cpp 复制代码
#include<stdio.h>
int q[] = { 1,2,3,3,7,7,7,8,9 }, k = 3;//k为查找的数
int Binary_search(int q[], int l, int r) {
	int i = l - 1, j = r + 1, mid;
	while (i+1 != j) 
	{
		mid = (i + j) >> 1;
		
		if (q[mid] < k)
		{
			i = mid;
		}
		else
		{
			j = mid;
		}
	}
	return i;
}
int main() {
	
	int len = sizeof(q) / sizeof(q[0]);
	int res = Binary_search(q, 0, len - 1);

	printf("%d", res);
	return 0;
}

三、浮点数二分

cpp 复制代码
#include<iostream>
using namespace std;
#include<cstdio>
#include<algorithm>
double x;

double max(double x, double y)
{
	return x > y ? x : y;
}

double fBi_search(double l, double r) 
{
	double mid;
	while (r - l > 1e-8) 
	{
		mid = (l + r) / 2;
		if (mid * mid <= x)
		{
			l = mid;
		}
		else
		{
			r = mid;
		}
	}
	return l;
}
int main() 
{
	//求根号x
	cin >> x;
	cout<<fBi_search(0, max(1, x));
	return 0;
}
相关推荐
南境十里·墨染春水4 小时前
C++传记(面向对象)虚析构函数 纯虚函数 抽象类 final、override关键字
开发语言·c++·笔记·算法
无巧不成书02184 小时前
30分钟入门Java:从历史到Hello World的小白指南
java·开发语言
2301_797172754 小时前
基于C++的游戏引擎开发
开发语言·c++·算法
比昨天多敲两行6 小时前
C++ 二叉搜索树
开发语言·c++·算法
Season4506 小时前
C++11之正则表达式使用指南--[正则表达式介绍]|[regex的常用函数等介绍]
c++·算法·正则表达式
问好眼6 小时前
《算法竞赛进阶指南》0x04 二分-1.最佳牛围栏
数据结构·c++·算法·二分·信息学奥赛
Birdy_x6 小时前
接口自动化项目实战(1):requests请求封装
开发语言·前端·python
海海不瞌睡(捏捏王子)6 小时前
C++ 知识点概要
开发语言·c++
桌面运维家7 小时前
VLAN配置进阶:抑制广播风暴,提升网络效率
开发语言·网络·php
一轮弯弯的明月8 小时前
Python基础-速通秘籍(下)
开发语言·笔记·python·学习