原题链接:蓝桥杯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、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复