IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> Piggy-Bank -> 正文阅读

[开发测试]Piggy-Bank

Problem Description
Before ACM can do anything, a budget must be prepared and the necessary financial support obtained. The main income for this action comes from Irreversibly Bound Money (IBM). The idea behind is simple. Whenever some ACM member has any small money, he takes all the coins and throws them into a piggy-bank. You know that this process is irreversible, the coins cannot be removed without breaking the pig. After a sufficiently long time, there should be enough cash in the piggy-bank to pay everything that needs to be paid.(问题描述;在ACM可以做任何事情之前,必须编制预算并获得必要的财务支持。这一行动的主要收入来自不可逆绑定货币(IBM)。背后的想法很简单。每当某个ACM成员有小钱时,他就会把所有的硬币都扔进存钱罐。你知道这个过程是不可逆的,不打碎猪就不能取出硬币。足够长的时间后,储钱罐里应该有足够的现金来支付所有需要支付的费用。)

But there is a big problem with piggy-banks. It is not possible to determine how much money is inside. So we might break the pig into pieces only to find out that there is not enough money. Clearly, we want to avoid this unpleasant situation. The only possibility is to weigh the piggy-bank and try to guess how many coins are inside. Assume that we are able to determine the weight of the pig exactly and that we know the weights of all coins of a given currency. Then there is some minimum amount of money in the piggy-bank that we can guarantee. Your task is to find out this worst case and determine the minimum amount of cash inside the piggy-bank. We need your help. No more prematurely broken pigs!(但是存钱罐有一个大问题。无法确定里面有多少钱。所以我们可能会把猪撕成碎片,却发现没有足够的钱。显然,我们想避免这种不愉快的情况。唯一的可能是称一下存钱罐,试着猜猜里面有多少硬币。假设我们能够准确地确定猪的重量,并且我们知道给定货币的所有硬币的重量。然后存钱罐里有一些我们可以保证的最低金额。你的任务是找出最糟糕的情况,并确定存钱罐中的最小现金量。我们需要你的帮助。再也没有过早破碎的猪了!)

Input
The input consists of T test cases. The number of them (T) is given on the first line of the input file. Each test case begins with a line containing two integers E and F. They indicate the weight of an empty pig and of the pig filled with coins. Both weights are given in grams. No pig will weigh more than 10 kg, that means 1 <= E <= F <= 10000. On the second line of each test case, there is an integer number N (1 <= N <= 500) that gives the number of various coins used in the given currency. Following this are exactly N lines, each specifying one coin type. These lines contain two integers each, Pand W (1 <= P <= 50000, 1 <= W <=10000). P is the value of the coin in monetary units, W is it’s weight in grams.(Input
The input consists of T test cases. The number of them (T) is given on the first line of the input file. Each test case begins with a line containing two integers E and F. They indicate the weight of an empty pig and of the pig filled with coins. Both weights are given in grams. No pig will weigh more than 10 kg, that means 1 <= E <= F <= 10000. On the second line of each test case, there is an integer number N (1 <= N <= 500) that gives the number of various coins used in the given currency. Following this are exactly N lines, each specifying one coin type. These lines contain two integers each, Pand W (1 <= P <= 50000, 1 <= W <=10000). P is the value of the coin in monetary units, W is it’s weight in grams.
Input
The input consists of T test cases. The number of them (T) is given on the first line of the input file. Each test case begins with a line containing two integers E and F. They indicate the weight of an empty pig and of the pig filled with coins. Both weights are given in grams. No pig will weigh more than 10 kg, that means 1 <= E <= F <= 10000. On the second line of each test case, there is an integer number N (1 <= N <= 500) that gives the number of various coins used in the given currency. Following this are exactly N lines, each specifying one coin type. These lines contain two integers each, Pand W (1 <= P <= 50000, 1 <= W <=10000). P is the value of the coin in monetary units, W is it’s weight in grams.(输入 ;由测试用例组成。它们的数量(T)在输入文件的第一行给出。每个测试用例以一行包含两个整数E和f开始。它们表示空的猪和装满硬币的猪的重量。两种重量都以克为单位。没有猪的体重会超过10公斤,也就是说1 <= E <= F <= 10000。在每个测试用例的第二行,有一个整数N (1 <= N <= 500),给出给定货币中使用的各种硬币的数量。紧随其后的是N行,每一行指定一种硬币类型。这两行各包含两个整数,Pand W (1 <= P <= 50000,1 <= W <=10000)。p是以货币单位表示的硬币价值,W是以克表示的重量。。)

Output
Print exactly one line of output for each test case. The line must contain the sentence “The minimum amount of money in the piggy-bank is X.” where X is the minimum amount of money that can be achieved using coins with the given total weight. If the weight cannot be reached exactly, print a line “This is impossible.”.(输出;为每个测试用例精确地打印一行输出。该行必须包含句子“存钱罐中的最小金额为X”,其中X是使用给定总重量的硬币可以获得的最小金额。如果不能准确达到重量,打印一行“这是不可能的。”。)

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<math.h>
#include<algorithm>
using namespace std;
int dp[10005]; || 定义一个数组为存钱猪。
int v[10005];  ||v为硬币的币值。
int w[10005];  || w为硬币的质量。
int main()
{
    int t;  || 定义总共需要t个测试。
    scanf("%d",&t);
    while(t--)  || 每测试一次次数减一。
    {
        int e,f,n,a;  || 定义a为硬币的总质量,f为满猪的质量,e为空猪的质量,n为硬币的种类。
        scanf("%d%d",&e,&f); 
        scanf("%d",&n); || 输入e,f,n。
        for(int i=0; i<n; i++)   || 定义从第一个硬币开始循环探索
        {
            scanf("%d%d",&v[i],&w[i]);  || 记录此硬币的币值,质量。
        }
        a=f-e;  || 满猪的质量减去空猪的质量等于硬币的总质量。
        for(int i=1; i<=a; i++)
        {
            dp[i]=10000000;   || 定义数组重量为这个范围内的最大值,以方便找到单位最小的硬币。
        }
        dp[0]=0;  || 数组为零时,硬币钱数为零。
        for(int i=0; i<n; i++)   ||定义i从第一个开始循环探索
        {
            for(int j=w[i]; j<=a; j++)  || 重新定义一个j为现在这个硬币的质量,若这个硬币的质量小于a,则继续循环。
            {
                dp[j]=min(dp[j],dp[j-w[i]]+v[i]);  || 第j个和i个的质量相等,取硬币币值小的那个。
            }
        }
        if(dp[a]<10000000) || 若数组小于最大值,则有情况把存钱猪装到相应硬币币值的重量。
            printf("The minimum amount of money in the piggy-bank is %d.\n",dp[a]);
        }
        else  || 反之则没有。
        {
            printf("This is impossible.\n");
        }
    }
    return 0;
}

这道题给出了硬币的类型,也就是说存钱猪里有多种硬币,这就需要比较硬币的重量和硬币的币值了,以找到最小值,然后根据质量确定满猪时候的最小金额。

  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2021-07-10 11:39:36  更:2021-07-10 11:40:26 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 12:08:35-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码