P8837 [传智杯 #3 决赛] 商店(贪心加双指针)

题目背景

思路解析:很经典的贪心问题,把物品按照从便宜到贵的顺序排好序,然后按照富贵程度排人,直接暴力会tle所以这里采用双指针.

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<string>
using namespace std;
int n, m, res;
int qian[100005], jia[100005];
int main()
{
    cin >> n >> m;
    for (int i = 0; i < n; i++)
        cin >> qian[i];
    for (int i = 0; i < m; i++)
        cin >> jia[i];
    sort(qian, qian + n);
    sort(jia, jia + m);//排序
    int j = 0, i = 0;
    while(1)//循环往后
     //i代表了钱数的坐标,j代表了价格的坐标
    {
        if (i > n || j > m) break;//表示越界直接break
        if (qian[i]>=jia[j])//钱够直接买
        {
            res++;
            i++;
            j++;
        }
        else{
            i++;//让钱多的人来
        }
    }
    cout << res;
    return 0;
}
相关推荐
EQUINOX115 小时前
倍增优化dp,P10976 统计重复个数
算法·数学建模·动态规划
样例过了就是过了15 小时前
LeetCode热题100 电话号码的字母组合
数据结构·c++·算法·leetcode·dfs
nervermore99015 小时前
1.10 面试经典150题-多数元素
算法
c++逐梦人15 小时前
二分查找模版及二分答案例题
算法·蓝桥杯
biubiuibiu15 小时前
选择适合的硬盘:固态与机械硬盘的对比与推荐
c++·算法
big_rabbit050215 小时前
[算法][力扣226]翻转一颗二叉树
数据结构·算法·leetcode
TracyCoder12315 小时前
LeetCode Hot100(65/100)——64. 最小路径和
算法·leetcode·职场和发展
z2014z15 小时前
Deflate 算法详解
网络·算法
条tiao条15 小时前
从 “Top-K 问题” 入门二叉堆:C 语言从零实现与经典应用
c语言·算法·深度优先
uesowys15 小时前
华为OD算法开发指导-数据结构-图
数据结构·算法·华为od