带分数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 中所有可以使数字和为 ...
随机推荐
- Python调用7zip命令实现文件批量解压
Python调用7zip命令实现文件批量解压 1.输入压缩文件所在的路径 2.可以在代码中修改解压到的文件路径和所需要解压的类型,列入,解压文件夹下面所有的mp4格式的文件 3.cmd 指的就是Pyt ...
- iOS富文本组件的实现—DTCoreText源码解析 渲染篇
本文转载至 http://blog.cnbang.net/tech/2729/ 上一篇介绍了DTCoreText怎样把HTML+CSS解析转换成NSAttributeString,本篇接着看看怎样把N ...
- 【LeetCode OJ】Add Two Numbers
题目:You are given two linked lists representing two non-negative numbers. The digits are stored in re ...
- Android学习之RadioGroup和RadioButton
转载自:http://my.oschina.net/amigos/blog/59261 实现RadioButton由两部分组成,也就是RadioButton和RadioGroup配合使用.RadioG ...
- /etc/fstab文件损坏的补救措施
最近乱搞,把/etc/fstab弄坏了,导致无法进入图形界面,而且所有文件都是只读的(简直郁闷到底啊),查了好多资料什么的终于弄好了,也走了不少弯路 恩,我不喜欢扯太多东西,这个是补救的帖子,还是希望 ...
- 【分享】Linux(Ubuntu)下如何自己编译JDK
最近在看<深入理解 Java 虚拟机>这本书.里面提到了如何手动编译JDK,于是就试了试. 在编译的过程中,遇到了一些问题.上网一搜,发现了一篇很好的文章,跟大家分享一下:ubuntu 1 ...
- Python pyQt4/PyQt5 学习笔记3(绝对对位,盒布局,网格布局)
本节研究布局管理的内容. (一)绝对对位 import sys from PyQt4 import QtGui class Example(QtGui.QWidget): def __init__( ...
- POJ 2386 Lake Counting(搜索联通块)
Lake Counting Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 48370 Accepted: 23775 Descr ...
- expect小工具,在postgresql中执行sql的shell脚本
脚本内容: #!/usr/bin/expect set database [lindex $argv 0] set username [lindex $argv 1] set password [li ...
- [工具]Sublime 显示韩文