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;
}
相关推荐
刀法如飞3 分钟前
Python列表去重:从新手三连到高阶特技,20种解法全收录
python·算法·编程语言
minji...5 分钟前
算法题 动态规划
算法·动态规划
水蓝烟雨29 分钟前
3337. 字符串转换后的长度 II
算法·leetcode
MegaDataFlowers33 分钟前
SiliconCompiler workflow
算法
_日拱一卒42 分钟前
LeetCode:226翻转二叉树
数据结构·算法·leetcode
BirdenT1 小时前
20260424紫题训练
c++·算法
还是阿落呀1 小时前
基本控制结构
开发语言·c++·算法
样例过了就是过了1 小时前
LeetCode热题100 最长有效括号
c++·算法·leetcode·动态规划
wayz111 小时前
Day 18:Keras深度学习框架入门
人工智能·深度学习·神经网络·算法·机器学习·keras
一行代码一行诗++1 小时前
C语言中if的使用
c语言·c++·算法