二分算法练习

目录

一、在排序数组中查找元素的第一个和最后一个位置

二、牛可乐和魔法封印

三、A-B数对

四、烦恼的高考志愿


一、在排序数组中查找元素的第一个和最后一个位置

34. 在排序数组中查找元素的第一个和最后一个位置 - 力扣(LeetCode)

答案如下:

cpp 复制代码
class Solution {
public:
    vector<int> searchRange(vector<int>& nums, int target) {
        int n = nums.size();
        if(n == 0)
        {
            return {-1,-1};
        }
        auto it1 = lower_bound(nums.begin(),nums.end(),target);
        auto it2 = upper_bound(nums.begin(),nums.end(),target);
        if(it1 == nums.end() || *it1 != target)
        {
            return {-1,-1};
        }
        int left = it1 - nums.begin();
        int right = it2 - nums.begin() - 1;
        return {left,right};
    }
};

二、牛可乐和魔法封印

牛可乐和魔法封印

答案如下:

cpp 复制代码
#include<iostream>
using namespace std;

const int N = 1e5 + 10;
int a[N];
int n;

int binary_search(int x, int y)
{
    int left = 1, right = n;
    while(left < right)
    {
        int mid = left + (right - left)/2;
        if(a[mid] >= x)
        {
            right = mid;
        }
        else{
            left = mid + 1;
        }
    }
    if(a[left] < x) return 0;
    int tmp = left;
    left = 1; right = n;
    while(left < right)
    {
        int mid = left + (right - left + 1)/2;
        if(a[mid] > y)
        {
            right = mid - 1;
        }
        else{
            left = mid;
        }
    }
    if(a[left] > y) return 0;
    return right - tmp + 1;
}

int main()
{
    cin >> n;
    for(int i = 1; i <= n; i++)
    {
        cin >> a[i];
    }
    int q; cin >> q;
    while(q--)
    {
        int x,y; cin >> x >> y;
        cout << binary_search(x,y) << endl;;
    }
    return 0;
}

三、A-B数对

P1102 A-B 数对 - 洛谷

答案如下:

cpp 复制代码
#include<iostream>
#include<unordered_map>
using namespace std;

const int N = 2e5 + 10;
typedef long long LL;
unordered_map<int, int> mp;
int a[N];

int main()
{
	int n,c; cin >> n >> c;
	for(int i = 0; i < n; i++)
	{
		cin>>a[i];
		mp[a[i]]++;
	}
	LL ret = 0;
	for(int i = 0; i < n; i++)
	{
		ret += mp[c + a[i]];
	}
	cout << ret << endl;
	return 0;
}

四、烦恼的高考志愿

P1678 烦恼的高考志愿 - 洛谷

答案如下:

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

typedef long long LL;

const int N = 1e5 + 10;
int a[N];
int m,n;

int find(int x)
{
	int left = 1, right = m;
	while(left < right)
	{
		int mid = (left + right)/2;
		if(a[mid] >= x)
		{
			right = mid;
		}
		else{
			left = mid + 1;
		}
	}
	return left;
}

int main()
{
	cin >> m >> n;
	for(int i = 1; i <= m; ++i)
	{
		cin >> a[i];
	}
	sort(a+1,a+1+m);
	a[0] = -1e8;
	LL ret = 0;
	for(int i = 1; i <= n; ++i)
	{
		int b; cin >> b;
		int pos = find(b);
		ret += min(abs(a[pos] - b), abs(a[pos-1] - b));
	}
	cout << ret << endl;
	return 0;
 } 
相关推荐
kisshyshy9 小时前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
众少成多积小致巨11 小时前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
猿人谷17 小时前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络18 小时前
Stable Diffusion 视觉大模型微调技术深度调研
算法
复杂网络18 小时前
基于 Stable Diffusion 架构的视觉大模型代表性工作与原理深度解析
算法
MrZhao40018 小时前
Agent Loop 如何用 Hook 扩展:权限、日志与工具拦截
算法
MrZhao40018 小时前
Agent 为什么需要 Skills:别把所有知识都塞进 system prompt
算法
JieE2122 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2123 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack203 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法