带分数dfs+剪枝优化
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<ctime>
using namespace std;
int num=1;
int sum=0;
int A=1,B=1,C=1; // num=a+b/c ,a,b,c所对应的长度
int abc[11];//储存a,b,c的值
int is[10]={0};
int a=0,b=0,c=0;
int power(int x,int y)
{
int pow =1;
for(int i=0;i<y;i++)
pow=pow*x;
return pow;
}
int cal(char n)
{
int sum=0;
if(n=='C')
for(int i=1;i<=C;i++)
sum+=abc[i]*power(10,C-i);
if(n=='B')
for(int i=C+1;i<=C+B;i++)
sum+=abc[i]*power(10,C+B-i);
if(n=='A')
for(int i=C+B+1;i<=9;i++)
sum+=abc[i]*power(10,9-i);
return sum;
}
void f(int n) //从c-b-a根据位数取值放到abc数组保存,判断
{
if(n>C+B)
{
c=cal('C');
b=cal('B');
//剪枝2 b必须大于c
if(b<c) return ;
//剪枝3 b/c必须为整数
if(b%c!=0) return ;
int s=b/c;
//剪枝4,b/c必须小于num
if(s>num) return ;
}
if(n==10) //取值完毕
{
a=cal('A');
if(a+b/c==num )
{
/* printf("%d = ",num);
for(int i=1;i<=A;i++)
printf("%d",abc[B+C+i]);
printf("+");
for(int i=1;i<=B;i++)
printf("%d",abc[C+i]);
printf("/");
for(int i=1;i<=C;i++)
printf("%d",abc[i]);
printf("\n");*/
sum++;
}
return ;
}
for(int i=1;i<=9;i++)
{
if(is[i]==0)
{
is[i]=1;
abc[n]=i;//按位储存c的值
f(n+1);
abc[n]=0;
is[i]=0;
}
}
}
int main()
{
cin>>num;
/*剪枝一*/
for(C=1;C<=4;C++) //分母长度最多为4位
for(B=C;B<=7,B+C<=8;B++) //分子位数不低于父母位数且要保证A的长度
{
A=9-B-C;
f(1);
}
cout<<sum<<endl;
printf("Time used = %.2f",(double)clock()/CLOCKS_PER_SEC);// 注意题目时间
return 0;
}
带分数dfs+剪枝优化的更多相关文章
- hdu 4109 dfs+剪枝优化
求最久时间即在无环有向图里求最远路径 dfs+剪枝优化 从0节点(自己添加的)出发,0到1~n个节点之间的距离为1.mt[i]表示从0点到第i个节点眼下所得的最长路径 #include<iost ...
- 搜索(剪枝优化):HDU 5113 Black And White
Description In mathematics, the four color theorem, or the four color map theorem, states that, give ...
- DFS剪枝处理HDU1010
http://acm.hdu.edu.cn/showproblem.php?pid=1010 题意很好理解,不是最短路,而是dfs,虽然地图不算大,稍微注意一点的dfs也能险过,但是700+ms和78 ...
- hdu 5887 Herbs Gathering (dfs+剪枝 or 超大01背包)
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=5887 题解:这题一看像是背包但是显然背包容量太大了所以可以考虑用dfs+剪枝,贪心得到的不 ...
- 生日蛋糕 (poj1190) (dfs剪枝)
[题目描述] 7月17日是Mr.W的生日,ACM-THU为此要制作一个体积为Nπ的M层生日蛋糕,每层都是一个圆柱体. 设从下往上数第i(1 <= i <= M)层蛋糕是半径为Ri, 高度为 ...
- [Codeforces 163D]Large Refrigerator (DFS+剪枝)
[Codeforces 163D]Large Refrigerator (DFS+剪枝) 题面 已知一个长方体的体积为V,三边长a,b,c均为正整数,求长方体的最小表面积S V以质因数分解的形式给出 ...
- [vijos1048]送给圣诞夜的贺卡<DFS剪枝>
题目链接:https://www.vijos.org/p/1048 很多人一看就想出了思路,不就是一个裸的dfs蛮...但是..在n<=50的情况下,朴素会直接tle..... 然后我就开始剪枝 ...
- Sticks(UVA - 307)【DFS+剪枝】
Sticks(UVA - 307) 题目链接 算法 DFS+剪枝 1.这道题题意就是说原本有一些等长的木棍,后来把它们切割,切割成一个个最长为50单位长度的小木棍,现在想让你把它们组合成一个个等长的大 ...
- 图解Leetcode组合总和系列——回溯(剪枝优化)+动态规划
Leetcode组合总和系列--回溯(剪枝优化)+动态规划 组合总和 I 给定一个无重复元素的数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 ...
随机推荐
- inux跟踪线程的方法:LWP和strace命令
摘要:在使用多线程程序时,有时会遇到程序功能异常的情况,而这种异常情况并不是每次都发生,很难模拟出来.这时就需要运用在程序运行时跟踪线程的手段,而linux系统的LWP和strace命令正是这种技术手 ...
- 《C++ Primer Plus》第17章 输入、输出和文件 学习笔记
流是进出程序的字节流.缓冲区是内存中的临时存储区域,是程序与文件或其他I/O设备之间的桥梁.信息在缓冲区和文件之间传输时,将使用设备(如磁盘驱动器)处理效率最高的尺寸以大块数据的方式进行传输.信息在缓 ...
- Mac 下如何下载、启动和关闭Tomcat 和管理Mac自带的Apache
Mac 下载.启动和关闭Tomcat 1. 下载Tomcat(地址:tomcat.apache.org),选择适合的版本(这里选择6.0.48),点击“Download”,之后在新页面点击“Core ...
- 【Spring Boot&&Spring Cloud系列】Spring Boot项目集成Swagger UI
前言 Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务.总体目标是使客户端和文件系统作为服务器以同样的速度来更新.文件的方法,参数和模型紧密集 ...
- mint下截图工具shutter的安装和使用设置
[原创作品,技术交流.允许转载,转载时请务必以超链接形式标明文章原始出处 .作者信息.如有错误,请指正] /** author: lihaibo date: 1/25/2016 */ 今天安装了双系统 ...
- [Apio2008]免费道路[Kruscal]
3624: [Apio2008]免费道路 Time Limit: 2 Sec Memory Limit: 128 MBSec Special JudgeSubmit: 1292 Solved: ...
- vscode 使用sublime风格代码
Monokai 主题 One Dark Pro主题 vscode设置字体 "editor.fontFamily": "MONACO, Consolas, 'Couri ...
- 【CF827E】Rusty String 调和级数+FFT
[CF827E]Rusty String 题意:给你一个01串,其中部分字符是'?',?可以是0或1,求所有可能的d,满足存在一种可能得到的01串,在向右移动d格后与自己相同. $n\le 5\tim ...
- Android 使用MediaPlayer 播放 视频
http://pan.baidu.com/s/1lgKLS package cn.bgxt.surfaceviewdemo; import java.io.File; import android.m ...
- MVC + ajaxform 文件上传
一.前端cshtml代码 <tr> <td width="130" align="right">添加附件:</td> @us ...