原题链接:蓝桥杯2013年第四届真题-带分数
解题思路:1.dfs或者STL的next_permutation构建1~9个数的所有排列
2.找出整数,分母,分子各自的位数范围
3.写出由数组位数求出该数的值的算法 (可类比求逆序数的算法)
4.暴力搜索统计即可!
注意事项: 1.整数位数最大只能为7 2.分子位数必须大于分母位数 3.分母位数不能没有
4.最后判断 整数+分子/分母==N&&分子%分母==0 缺一不可!!
5.还一个很坑的地方,求分子分母位数时,最好控制分母的位数,因为有上限为9,便于控制
如果控制分子来弄,会报错50%,因为分母的范围被缩小了! 体会很深。。。错很多次50%了
参考代码: 这是dfs版本的
#include<iostream> using namespace std; int a[10]={0,1,2,3,4,5,6,7,8,9}; bool book[10]; int total=0,N; //把获取的数组起终点下标转化成数 int getNum(int x,int y){ int num=0; for(int i=x;i<=y;i++){ num=num*10+a[i]; } return num; } //判断是否符合等式要求 void judge(int a[]){ int i,j; //整数位的范围是1~7 for(i=1;i<=7;i++){ //先求整数 int integer=getNum(1,i); //控制分母范围较好,因为控制分子的话,分母的范围会被降低!! for(j=(9-i)/2+i;j<=9;j++){ int fz=getNum(i+1,j-1); //分子必须留一位给分母 int fm=getNum(j,9); if(integer+fz/fm==N&&(fz%fm)==0) total++; } } } //求9个数的全排列 void dfs(int step){ if(step==10){ judge(a); } for(int i=1;i<=9;i++){ if(book[i]==0){ a[step]=i; book[i]=1; dfs(step+1); book[i]=0; } } } int main(){ cin>>N; dfs(1); cout<<total; return 0;}
下面是STL的next_permutation版本的 后面的要简洁一点!!
#include<iostream> #include<algorithm> using namespace std; int a[10]={0,1,2,3,4,5,6,7,8,9}; bool book[10]; int total=0,N; //把获取的数组起终点下标转化成数 int getNum(int x,int y){ int num=0; for(int i=x;i<=y;i++){ num=num*10+a[i]; } return num; } //判断是否符合等式要求 void judge(int a[]){ int i,j; //整数位的范围是1~7 for(i=1;i<=7;i++){ //先求整数 int integer=getNum(1,i); //控制分母范围较好,因为控制分子的话,分母的范围会被降低!! for(j=(9-i)/2+i;j<=9;j++){ int fz=getNum(i+1,j-1); //分子必须留一位给分母 int fm=getNum(j,9); if(integer+fz/fm==N&&(fz%fm)==0) total++; }}} int main(){ cin>>N; do{ judge(a); }while(next_permutation(a+1,a+10)); cout<<total; return 0;}
0.0分
9 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复