| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 783 人关注过本帖
标题:再次求助1元钱分解为5角2角1角的问题
只看楼主 加入收藏
大大猫
Rank: 1
等 级:新手上路
帖 子:44
专家分:0
注 册:2011-8-19
结帖率:81.25%
收藏
已结贴  问题点数:20 回复次数:5 
再次求助1元钱分解为5角2角1角的问题
求一共的分法,要求不能用穷举法做,实在没找到这个问题的解法,用递归做的,出现了很多重复情况,怎么可以去掉这些重复呢,哪位好心人帮忙改下吧,十分感谢啊!!!!!
这个问题上次问过了,可是我没看懂就结贴了,再也不着急结贴了
int a[10],m[4]={10,5,2,1};
int sum(int a[],int n)
{
   int i,s=0;
   for(i=0;i<=n;i++)
      s=s+a[i];
   return s;
}
void prin(int a[],int n)
{
   int i;
   for(i=0;i<=n;i++)
     printf("%d ",a[i]);
   printf("\n");
}
void divide(int i,int top,int number)
{
    int j;
   for(j=0;j<4;j++)
   {
       a[top]=m[j];
       if(number==sum(a,top))
       {
           prin(a,top); continue;
       }
       else if(number<sum(a,top)) continue;
       if(top>=number) continue;
       divide(m[j],top+1,number);
   }
}
void main()
{
   int number=10,top=0;
   int i=0;
   divide(i,top,number);
}
好像是递归的次数多了,不知道怎么改啊,这个还是参照一个别的问题的解法,求帮忙啊!!!!
搜索更多相关主题的帖子: return number 
2011-11-06 18:47
czz5242199
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:4
帖 子:660
专家分:2400
注 册:2011-10-26
收藏
得分:0 
递归参数中再加一个参数,就是上一次用的面值,然后规定下一次的面值>=这一次的面值,这样就没有重复
2011-11-06 18:59
大大猫
Rank: 1
等 级:新手上路
帖 子:44
专家分:0
注 册:2011-8-19
收藏
得分:0 
回复 2楼 czz5242199
你能直接帮我改下吗 我现在有点乱
2011-11-06 19:35
czz5242199
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:4
帖 子:660
专家分:2400
注 册:2011-10-26
收藏
得分:0 
懒得弄了,参见此贴我的回答,方法很类似https://bbs.bccn.net/thread-354190-1-2.html
2011-11-06 20:55
Devil_W
Rank: 10Rank: 10Rank: 10
等 级:青峰侠
威 望:9
帖 子:1160
专家分:1797
注 册:2009-9-14
收藏
得分:0 
where is the code?

[ 本帖最后由 Devil_W 于 2011-11-6 21:28 编辑 ]
2011-11-06 21:13
江上明月
Rank: 2
等 级:论坛游民
帖 子:2
专家分:20
注 册:2011-11-4
收藏
得分:20 
#include<stdio.h>
void main()
{
    int sum;/*金额*/
    int i,j;/**/
    printf("Qing shu ru jin e (Dan wei :yuan)");
    scanf("%d",&sum);
    sum=10*sum;
    for(i=0;i<=sum/5;i++)
    {
        for(j=0;j<=(sum-5*i)/2;j++)
        {
            printf("wujiao:%d\t  liangjiao:%d\t  yijiao:%d\n",i,j,sum-5*i-
2*j);
        }
    }
}
拼音  你懂得

IT  挨踢
2011-11-07 11:02
快速回复:再次求助1元钱分解为5角2角1角的问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.039486 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved