• 钞票的面值兑换



    题目:编一个程序,把一张面值100元的钞票换成5元,1元和5角面值的钞票,要求100元换以上的零钱100张,且要求每种不少于一张。 请问,有哪几种换法?把每种算法打印出来。

    我的思路:

    题目中可看出要满足3个条件:1.总面值100元;2.张数100;3.每种面值每种不少于一张。可利用3重循环,找出满足条件的数。具体实现代码如下:

                int n = 0;//计数
    
                //i、j、z初始值为1,满足条件每种面值每种不少于一张
                for (int i = 1; i <= 20; i++)
                {
                    for (int j = 1; j <= 100; j++)
                    {
                        for (int z = 0; z < 200; z++)
                        {
                            //满足总面值100元、张数100条件
                            if ((5 * i + j + 0.5 * z) == 100 && i + j + z == 100)
                            {
                                Console.WriteLine("5元{0}张,1元{1}张,5角{2}张",i,j,z);
                                n++;
                            }
                        }
                    }
                }
                Console.WriteLine("总共{0}种换法",n);

     结果如下:

  • 相关阅读:
    .hpp文件
    最小高度的BST
    检查图中的有向路径
    c++ 对象内存布局详解
    链表求差
    offer--链表反转和从尾到头打印链表
    平衡二叉树的判断
    java 抽象类和接口
    原型模式--prototype
    装饰模式decorator
  • 原文地址:https://www.cnblogs.com/beimingdaoren/p/12557120.html
Copyright © 2020-2023  润新知