【PTA数据结构 | C语言版】两枚硬币

本专栏持续输出数据结构题目集,欢迎订阅。

文章目录

题目

伊娃喜欢收集全宇宙的硬币,包括火星币等等。一天她到了一家宇宙商店,这家商店可以接受任何星球的货币,但有一个条件,无论什么价格,都必须用 2 枚硬币一次付清,不能多也不能少。而她有多达 10^5 个硬币,于是求助于你。给定任一价格,请帮她找出可以付款的 2 枚硬币。

输入格式:

第 1 行给出 2 个正整数:n (≤10^5 )为硬币枚数、m(≤10^3 )为伊娃要付清的价格;第 2 行给出 n 枚硬币的面值,均为不超过 500 的正整数。同行数字间以空格分隔。

输出格式:

在一行中输出两枚硬币的面值 v1 和 v2,以 1 个空格分隔,满足条件 v1​ +v2 =m,并且 v1 ≤v2。如果这样的解不唯一,输出 v1 最小的那个解。如果解不存在,则输出 No Solution。

输入样例 1:

8 15

1 2 8 7 2 4 11 15

输出样例 1:

4 11

输入样例 2:

7 14

1 8 7 2 4 11 15

输出样例 2:

No Solution

题目引用自攀拓考试真题(2012年冬季)。

代码

c 复制代码
#include <stdio.h>
#include <stdlib.h>

int compare(const void *a, const void *b) {
    return (*(int*)a - *(int*)b);
}

int main() {
    int n, m;
    scanf("%d %d", &n, &m);
    
    int coins[100000];
    for (int i = 0; i < n; i++) {
        scanf("%d", &coins[i]);
    }
    
    // 对硬币进行排序
    qsort(coins, n, sizeof(int), compare);
    
    int left = 0, right = n - 1;
    int found = 0;
    
    // 双指针法查找符合条件的硬币对
    while (left < right) {
        int sum = coins[left] + coins[right];
        if (sum == m) {
            printf("%d %d\n", coins[left], coins[right]);
            found = 1;
            break;
        } else if (sum < m) {
            left++;
        } else {
            right--;
        }
    }
    
    if (!found) {
        printf("No Solution\n");
    }
    
    return 0;
}
相关推荐
黑客思维者1 小时前
《我是如何用C语言写工控系统的漏洞和Bug》连载(1)内容大纲
c语言·bug·工控漏洞
j_xxx404_1 小时前
数据结构:栈和队列力扣算法题
c语言·数据结构·算法·leetcode·链表
南莺莺2 小时前
假设一个算术表达式中包含圆括号、方括号和花括号3种类型的括号,编写一个算法来判别,表达式中的括号是否配对,以字符“\0“作为算术表达式的结束符
c语言·数据结构·算法·
THMAIL2 小时前
深度学习从入门到精通 - 神经网络核心原理:从生物神经元到数学模型蜕变
人工智能·python·深度学习·神经网络·算法·机器学习·逻辑回归
野犬寒鸦2 小时前
力扣hot100:旋转图像(48)(详细图解以及核心思路剖析)
java·数据结构·后端·算法·leetcode
墨染点香2 小时前
LeetCode 刷题【61. 旋转链表】
算法·leetcode·职场和发展
一枝小雨2 小时前
【OJ】C++ vector类OJ题
数据结构·c++·算法·leetcode·oj题
Tisfy3 小时前
LeetCode 3516.找到最近的人:计算绝对值大小
数学·算法·leetcode·题解
自信的小螺丝钉3 小时前
Leetcode 206. 反转链表 迭代/递归
算法·leetcode·链表
buyutang_3 小时前
C/C++ Linux系统编程:线程控制详解,从线程创建到线程终止
linux·c语言·c++·学习