HDU1258 DFS

题意:求n个数中的某些数的和等于t,并输出

dfs

记录下已经输出过的,然后每次比较一下,这样就能避免重复

View Code
  1 #include<stdio.h>
  2 #include<string.h>
  3 #include<stdlib.h>
  4 #include<algorithm>
  5 using namespace std;
  6 const int maxn = 15;
  7 const int maxm = 500005;
  8 int num[ maxn ];
  9 int vis[ maxn ];
 10 int ans[ maxn ];
 11 int t,n;
 12 int flag;
 13 int new_start;
 14 struct node{
 15     int cnt;
 16     int ans[ maxn ];
 17 }my[ maxm ],temp;
 18 int cnt_my;
 19 int judge( ){
 20     sort( temp.ans,temp.ans+temp.cnt );
 21     for( int i=0;i<cnt_my;i++ ){
 22         if( temp.cnt==my[i].cnt ){
 23             int k;
 24             int fff=1;
 25             for( k=0;k<temp.cnt;k++ ){
 26                 if( temp.ans[k]==my[i].ans[k] )
 27                 {}
 28                 else{
 29                     fff=-1;
 30                     break;
 31                 }
 32             }
 33             if( fff==1 )
 34                 return i;//exist
 35         }
 36     }
 37     for( int i=0;i<temp.cnt;i++ ){
 38         my[ cnt_my ].ans[ i ]=temp.ans[i];
 39     }
 40     my[ cnt_my ].cnt=temp.cnt;
 41     cnt_my++;
 42     return -1;
 43 }
 44 int judge2(int p){
 45     int sum=0;
 46     for( int i=p;i<=n;i++ ){
 47         sum+=num[i];
 48     }
 49     return sum;
 50 }
 51 void dfs( int pos,int sum,int cnt ){
 52     if( sum==t ){
 53         temp.cnt=cnt;
 54         for( int i=0;i<cnt;i++ ){
 55             temp.ans[i]=ans[i];
 56         }
 57         if( judge()==-1 ){
 58             flag=1;
 59             for( int i=0;i<cnt;i++ ){
 60                 if( i==0 ) printf("%d",ans[i]);
 61                 else printf("+%d",ans[i]);
 62             }
 63             printf("\n");
 64         }
 65         //new_start++;
 66         return ;
 67     }
 68     for( int i=new_start;i<=n;i++ ){
 69         if( vis[ i ]==0&&(sum+num[i])<=t ){
 70             int ttt=judge2( i );
 71             for( int k=0;k<cnt;k++ )
 72                 ttt+=ans[k];
 73             if( ttt<t ) return ;
 74             vis[ i ]=1;
 75             ans[ cnt ]=num[i];
 76             dfs( i,sum+num[i],cnt+1 );
 77             vis[ i ]=0;
 78         }
 79     }
 80     return ;
 81 }
 82 
 83 int main(){
 84     while( scanf("%d%d",&t,&n),n ){
 85         for( int i=1;i<=n;i++ ){
 86             scanf("%d",&num[ i ]);
 87             vis[i]=0;
 88         }
 89         flag=-1;
 90         cnt_my=0;
 91         printf("Sums of %d:\n",t);
 92         for( int i=1;i<=n;i++ ){
 93             if( num[i]>t ) {
 94                 vis[i]=1;
 95                 continue;
 96             }
 97             if( num[i]==t&&flag==-1 ){//在这个判断条件上wa了一次!!!flag!=-1
 98                 flag=1;
 99                 vis[i]=1;
100                 my[ 0 ].cnt=1;
101                 my[ 0 ].ans[0]=t;
102                 cnt_my++;
103                 printf("%d\n",t);
104                 continue;
105             }
106             if( num[i]==t&&flag==1 ){
107                 vis[i]=1;
108                 continue;
109             }
110             new_start=i;
111             dfs( i,0,0 );//pos sum cnt
112             break;
113         }
114         if( flag==-1 )
115             printf("NONE\n");
116         //printf("end\n");
117     }
118     return 0;
119 }

 

转载于:https://www.cnblogs.com/xxx0624/archive/2013/02/17/2915029.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/409130.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python 问题--encode、decode及shell中文输出

最近在使用python的时候&#xff0c;涉及到中文输出的时候经常会出现乱码的问题&#xff0c;所以就上网搜索了下&#xff0c;参考了1.Python字符串的encode与decode研究心得乱码问题解决方法&#xff1b; 2.python 中编码的再次学习 此外&#xff0c;更多详细字符编码的可以看…

python 模块学习--Numpy

Numpy是Python的一个科学计算库&#xff0c;提供了矩阵运算的功能。安装方法可以直接使用pip install numpy命令&#xff0c;也可以在http://sourceforge.net/projects/numpy/files/NumPy/上下载与python相应版本的exe文件。 这里就记录下在学习和使用Numpy中所用过的一些函数…

mysql独有的函数_数据库之MySQL函数(一)

一、数学函数1、绝对值函数ABS(x) &#xff1a;返回 x 的绝对值mysql> select ABS(2),ABS(-2.3),ABS(-22);返回的结果如下&#xff1a;数学学得好的大佬应该知道(本人是个数学渣。。。。)&#xff0c;负数的绝对值是正数&#xff0c;正数的绝对值还是正数本身2、 返回圆周率…

teststand调用python模块_TestStand 基本知识[10]--在序列中调用代码模块之--LabVIEW

在TestStand调用外部代码模块时&#xff0c;使用频率最高的就是LabVIEW VI。下面调用TestStand Demo程序&#xff0c;可以看到如下图&#xff1a;1. 添加LabVIEW Action步骤,并创建或者加载VI。当添加LabVIEW步骤后&#xff0c;可以通过VI Path加载想要调用的VI(也可以创建模板…

C#事件机制(记住流程)

转自&#xff1a;http://jimmyloveforever.blog.163.com/blog/static/119775247200951303935836/ 1&#xff0c;C#事件机制是基于委托实现的&#xff0c;因此要首先定义一个委托EventHandler&#xff1a;public delegate void EventHandler(object from , myEventArgs e) Syste…

Android Studio 安装配置问题总结

之前一直都是使用Eclipse写Android的&#xff0c;但一直都有听说Android Studio是一个更好的用于开发Android的软件&#xff0c;之前其实也有保存过一些别人写的安装和配置Android Studio的一些教程&#xff0c;在这里也列出来&#xff1a;Android Studio 入门指南&#xff1b;…

说说mysql_说说MySQL权限 - andyqian的个人空间 - OSCHINA - 中文开源技术交流社区

本文首发于个人微信公众号《andyqian》,期待你的关注&#xff5e;前言今天继续MySQL系列文章&#xff0c;讲讲MySQL权限相关的内容。我们都知道&#xff0c;在写系统的时候&#xff0c;都会有权限相关的服务&#xff0c;以达到权限控制的目的。以最简单的权限菜单为例&#xff…

[机器学习笔记] Note1--机器学习简介

阅读本文大约需要 2 分钟 本文结构&#xff1a; 什么是机器学习监督学习(Supervised Learning)非监督学习(Unsupervised Learning)课程小结 这是学习 Andrew Ng 在 Coursea 上的机器学习课程所做的笔记。 什么是机器学习 对于机器学习&#xff0c;并没有一个一致认同的定义…

mysql执行过程五步_简单五步教你搭建MySQL主从复制

环境主机&#xff1a;172.17.0.2从机&#xff1a;172.17.0.3环境&#xff1a;CentOS7MySQL&#xff1a;5.6.38目标&#xff1a;实现主机172.17.0.2到从机172.17.0.3基于Binlog的主从复制目前MySQL提供两种方式主从复制&#xff1a;基于Binlog(我们此篇就是基于Binlog的主从复制…

[机器学习笔记] Note2--单变量线性回归

继续是机器学习课程的笔记&#xff0c;这节介绍的是单变量线性回归算法&#xff0c;线性回归算法也是一个比较基础的算法。 模型表达 首先是以房屋交易问题为例&#xff0c;假设我们回归问题的训练集如下表所示&#xff1a; Size in feet2feet2(x)Price($) in 1000’s (y)21…

linux打印mysql堆栈_第25问:MySQL 崩溃了,打印了一些堆栈信息,怎么读?

问题在 09 问中&#xff0c;我们开启了 coredump 功能&#xff0c;在 MySQL 崩溃时获得了有用的 coredump 信息。那如果没开启 coredump&#xff0c;仅有 error log 中的堆栈信息&#xff0c;我们如何分析有效的信息&#xff1f;实验我们沿用 09 问中的 MySQL 崩溃的场景&#…