| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1790 人关注过本帖, 1 人收藏
标题:ACM 一道题目 求大神给个思路或者代码
只看楼主 加入收藏
yangfrancis
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:141
帖 子:1510
专家分:7661
注 册:2014-5-19
收藏
得分:0 
回复 9楼 吹水佬
跟发票有什么关系?没听明白呢
2016-12-15 11:50
yangfrancis
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:141
帖 子:1510
专家分:7661
注 册:2014-5-19
收藏
得分:0 
回复 8楼 九转星河
由于用链表,只好用结构体
2016-12-15 11:52
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
回复 12楼 yangfrancis
其实也可以用递归,全组合是2^n-1,和完全二叉树、汉诺塔模型有些联系~只要掌控递归状态就行了~等下我发代码,注释写不了多少,要靠自己领悟~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2016-12-15 12:49
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
回复 13楼 九转星河
感觉原理和10楼差不多,只是写法有点出入~不过没有参考10楼,自己想的
程序代码:
#include<stdio.h>
#include<stdlib.h>

void judge(int a[],int k[],int n)
{
    int i=0;
    for (i=0;i<n+1;i++)
    if (k[i]==1)
            printf("%-3d",a[i]);
     
    printf("\n");
}
int fun(int a[],int k[],int x,int goal,int n,int size_a)   
{
    if (n!=-1)
  {
          fun(a,k,x,goal,n-1,size_a);

          if (x>goal)
              return (x);//这句是参考10楼的,原来加了没有影响~

          k[n]=-k[n];
          
          fun(a,k,x=x+a[n],goal,n-1,size_a);

          if (x==goal) 
              judge(a,k,size_a);      
              
           k[n]=-k[n];
    }
    return (x);
}
int main()
{
    int a[]={1,2,3,4,5,6,7,8,9,10};  
    int *k=(int*)malloc(sizeof(a));             //k为状态变量数组
    int goal=20;               //goal为目标数
    int n=sizeof(a)/sizeof(int)-1;  //n为遍历状态的最大位数
    
    memset(k,-1,sizeof (a));
        
    fun(a,k,0,goal,n,n);  

    return 0;
}


[此贴子已经被作者于2016-12-15 15:14编辑过]


[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2016-12-15 12:56
吹水佬
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:451
帖 子:10607
专家分:43186
注 册:2014-5-20
收藏
得分:0 
回复 11楼 yangfrancis
这是7楼代码的结果:
图片附件: 游客没有浏览图片的权限,请 登录注册

假设收到款项:60元
最近开出了6张发票,各张金额分别:1元、10元、11元、49元、50元、59元
来查发票的人问:收到的60元是属哪几张发票的?
查找结果,有可能是:
1、10、49 的三张发票
1、59 的二张发票
10、50 的二张发票
11、49 的二张发票
账务处理,往来款项严格来说是要逐笔核销。
如果业务往来多时,人工查找核对很费时,电脑核对就类似这道题的做法。
看到7楼代码的结果,就想起来查发票的人。


2016-12-15 15:08
快速回复:ACM 一道题目 求大神给个思路或者代码
数据加载中...
 
   



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

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