1209. 带分数 刷题笔记

思路 暴力匹配

读入目标数 n

看n是否与a+b/c相等

因为c++里面的除法是整除

我们将 n==a+b/c

转换为 c*n==a*c+b

那么如何获得a,b,c

依题意 a,b,c三个数由1-9九个数字组成

且每个数字只能出现一次

由此 我们可以搜出123456789的全部排列方式

然后 每次将这个九位数分成三部分

例如 a=12,b=4567,c=89

又假如 当前排列为 985476321

获得a=985,b=476,c=321;

或者

a=98,b=5476,c=321;

枚举出所有的分法

同时与目标值匹配即可

若相等 则计数++

#include<iostream>

#include<cstdio>

#include<algorithm>

#include<cstring >

using namespace std;

int n,cnt;

const int N=10;

bool used[N];

int st[N];

int num[10]={1,2,3,4,5,6,7,8,9};

int cal(int i,int j);

void dfss()

{

//双循环 枚举出所有的分法

for(int i=1;i<=6;i++){

for(int j=i+1;j<=8;j++){

int a=cal(1,i);

int b=cal(i+1,j);

int c=cal(j+1,9);

//cout<<a<<endl<<b<<endl<<c<<endl;

if(c*n==a*c+b){

cnt++;

}

}

}

//cout<<dsf(1);

}

void dfs(int u){

if(u>9){

//当u>9说明已经搜索出了一个排列

//修改num内存的值与当前排列相同

int ans=0;

for(int i=1;i<=9;i++){

num[i]=st[i] ;

// cout<<num[i]<<' ';

}

dfss();//计算当前排列是否匹配目标值

return ;

}

for(int i=1;i<=9;i++){

if(!used[i]){

used[i]=true;

st[u]=i;

dfs(u+1);

used[i]=false;

st[u]=0;

}

}

}

int cal(int i,int j){

int res=0;

for( ; i<=j;i++){

res=res*10+num[i];

}

//将num的值转化为a,b,c的值

return res;

}

int main(){

cin>>n;

dfs(1);

cout<<cnt;

return 0;

}

相关推荐
Always_away1 小时前
数据库系统概论|第三章:关系数据库标准语言SQL—课程笔记4
数据库·笔记·sql·学习
嵌入式小小怪下士1 小时前
lx2160 LSDK21.08 firmware 笔记 - 0.基于fip.bin 编译流程展开的 makefile 分析
笔记·lsdk21.08·lx2160/lx2080
在下_诸葛1 小时前
狂神SQL学习笔记六:列的数据类型讲解
笔记·sql·学习
Ⅰㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤ1 小时前
03 UV
笔记·学习·3dmax
christine-rr2 小时前
【25软考网工笔记】第二章 数据通信基础(4)数据编码
网络·笔记·信息与通信·软考·考试
zzh-3 小时前
【无标题】spark SQL核心编程
笔记
睡了吃-3 小时前
Spark-SQL核心编程
笔记
可乐^奶茶3 小时前
2026《数据结构》考研复习笔记一(C++基础知识)
数据结构·笔记·考研
归辞...7 小时前
【iOS】OC高级编程 iOS多线程与内存管理阅读笔记——自动引用计数(二)
笔记·ios·cocoa
DXM05217 小时前
牟乃夏《ArcGIS Engine地理信息系统开发教程》学习笔记2
开发语言·javascript·笔记·学习·arcgis·ae