A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© jiangenhao 中级黑马   /  2014-4-13 17:06  /  972 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 jiangenhao 于 2014-4-16 01:14 编辑

如果要将整钱换成零钱,那么一元钱可兑换成一角、两角、五角,问有多少种兑换方式

3 个回复

倒序浏览
#include<stdio.h>
int findway(onedollar)
{
    int i,j,k;//各票面值的张数
    int sum=0;//统计一共有多少种组成方式
    for(i=0;0.1*i<=onedollar;i++)
        for(j=0;j*0.2<=onedollar;j++)
            for(k=0;k*0.5<=onedollar;k++)
            {
                if(0.1*i+0.2*j+0.5*k==onedollar)//判断能否组成一元
                {
                    printf("%d个一角 %d个两角 %d个五角\n",i,j,k);
                    sum++;
                }
            }
    return sum;
}
int main()
{
    int onedollar=1;//输入要凑成的面值
    int total=findway(onedollar);
    printf("one dollar has %d make-up\n",total);
    return 0;
}

这个题方式有很多种,这个算法是最好理解的,但是缺点是时间复杂度太高了,看你能优化下不?

评分

参与人数 1技术分 +1 收起 理由
jing迪 + 1

查看全部评分

回复 使用道具 举报
众里寻他。。。
回复 使用道具 举报
那什么,我家用的是虚拟机,运行能通过,复制不出啦,就直接给你上图片了哈。。。
回复 使用道具 举报 1 0
您需要登录后才可以回帖 登录 | 加入黑马