PAT甲级-1048 Find Coins

题目

题目大意

给出硬币的个数n和要付费的钱m,接下来给出每个硬币的面值。要求从这些硬币中找到两个硬币v1, v2,使得v1 + v2 == m,且v1 < v2,输出v1 v2。如果不能找到这两个硬币,输出No Solution。

思路

刚开始用的模拟,即代码中被注释掉的部分,外循环从第一个硬币开始遍历,内循环从最后一个硬币开始遍历,但是有测试点超时。所以后来又改了二分法来查找。

代码

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

int n, m;
vector<int> v;

int erfen(int i){
    int low = i + 1, high = n - 1;
    while (low <= high){
        int mid = (low + high) / 2;
        if (v[mid] == m - v[i]){
            return v[mid];
        }else if (v[mid] > m - v[i]){
            high = mid - 1;
        }else{
            low = mid + 1;
        }
    }
    return -1;
}

int main(){
    cin >> n >> m;
    v.resize(n);
    for (int i = 0; i < n; i++){
        cin >> v[i];
    }

    sort(v.begin(), v.end());
    for (int i = 0; i < n; i++){
        /*for (int j = n - 1; j > i; j--){
            if (v[i] + v[j] == m){
                cout << v[i] << " " << v[j] << endl;
                return 0;
            }else if (v[i] + v[j] < m){
                break;
            }
        }*/
        int res = erfen(i);
        if (res != -1){
            cout << v[i] << " " << res << endl;
            return 0;
        }
    }

    cout << "No Solution" << endl;

    return 0;
}
相关推荐
q_30238195566 分钟前
破局路侧感知困境:毫米波雷达+相机融合算法如何重塑智能交通
数码相机·算法
Robert--cao7 分钟前
人机交互(如 VR 手柄追踪、光标移动、手势识别)的滤波算法
人工智能·算法·人机交互·vr·滤波器
枫叶丹49 分钟前
【Qt开发】Qt窗口(十) -> QInputDialog 输入对话框
c语言·开发语言·数据库·c++·qt
云青山水林9 分钟前
算法竞赛从入门到跳楼(ACM-XCPC、蓝桥杯软件赛等)
c++·算法·蓝桥杯
汪宁宇11 分钟前
MFC中从位图角度旋转图片示例代码
c++·mfc·图片·旋转
LYFlied11 分钟前
【每日算法】LeetCode138. 随机链表的复制
数据结构·算法·leetcode·链表
zore_c14 分钟前
【C语言手撕算法】LeetCode-142. 环形链表 II(C语言)
c语言·数据结构·算法·leetcode·链表·推荐算法
兵哥工控16 分钟前
mfc最简单自定义消息投递实例
c++·mfc·postmessage
yaoh.wang8 小时前
力扣(LeetCode) 13: 罗马数字转整数 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
T1ssy8 小时前
布隆过滤器:用概率换空间的奇妙数据结构
算法·哈希算法