HDOJ/HDU 2566 统计硬币(公式~遍历~)

简介: HDOJ/HDU 2566 统计硬币(公式~遍历~)

Problem Description

假设一堆由1分、2分、5分组成的n个硬币总面值为m分,求一共有多少种可能的组合方式(某种面值的硬币可以数量可以为0)。


Input

输入数据第一行有一个正整数T,表示有T组测试数据;

接下来的T行,每行有两个数n,m,n和m的含义同上。


Output

对于每组测试数据,请输出可能的组合方式数;

每组输出占一行。


Sample Input

2

3 5

4 8


Sample Output

1

2


这个问题和鸡兔同笼有点类似~


根据条件,可以列出3个未知数,和2和方程;


假设1分硬币数量为x,2分硬币数量为y,5分硬币数量为z.

x+2y+5z=m,x+y+z=n;

所以:m-n=4z+y,(x>=0,y>=0,z>=0)

n-z-y>=0(这个条件不要忘了)

import java.util.Scanner;
/**
 * @author 陈浩翔
 * 2016-5-18
 */
public class Main{
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int t =sc.nextInt();
        while(t-->0){
            int n =sc.nextInt();
            int m =sc.nextInt();
            int count=0;
            for(int y=0;y<=m/2;y++){
                for(int z=0;z<=m/5;z++){
                    if(4*z+y==m-n&&(n-z-y)>=0){
                        count++;
                    }
                }
            }
            System.out.println(count);
        }
    }
}
目录
相关文章
|
8月前
|
Java
hdu 2566 统计硬币
hdu 2566 统计硬币
35 0
|
9月前
华为机试HJ37:统计每个月兔子的总数(斐波那契数列)
华为机试HJ37:统计每个月兔子的总数(斐波那契数列)
|
SQL Shell
HDU-4348 To the moon(主席树区间修改 永久化标记)
HDU-4348 To the moon(主席树区间修改 永久化标记)
121 0
HDU-4348 To the moon(主席树区间修改 永久化标记)
HDU-2566,统计硬币(暴力 or DP)
HDU-2566,统计硬币(暴力 or DP)
HDOJ(HDU) 2521 反素数(因子个数~)
HDOJ(HDU) 2521 反素数(因子个数~)
98 0
|
机器学习/深度学习
HDOJ(HDU) 2083 简易版之最短距离(中位数)
HDOJ(HDU) 2083 简易版之最短距离(中位数)
123 0
HDOJ(HDU) 2156 分数矩阵(嗯、求和)
HDOJ(HDU) 2156 分数矩阵(嗯、求和)
90 0
HDOJ(HDU) 2138 How many prime numbers(素数-快速筛选没用上、)
HDOJ(HDU) 2138 How many prime numbers(素数-快速筛选没用上、)
86 0
HDOJ 2076 夹角有多大(题目已修改,注意读题)
HDOJ 2076 夹角有多大(题目已修改,注意读题)
86 0