解题思路:
dfs。分两种情况,4=1*4,4=2*3。
注意事项:
参考代码:
#include<iostream> #include<string.h> #include<algorithm> using namespace std; int a[10]={0},b[10]; int ans=0; int r=9; void dfs(int cur){ int i=0; if(cur==r){ int y2=b[5]*10+b[6],z2=b[7]*100+b[8]*10+b[9]; int x=b[1]*1000+b[2]*100+b[3]*10+b[4],y1=b[5],z1=b[6]*1000+b[7]*100+b[8]*10+b[9]; if(x==y1*z1){ ans++; if(ans==1)cout<<x<<" = "<<y1<<" x "<<z1; else cout<<endl<<x<<" = "<<y1<<" x "<<z1; } if(x==y2*z2){ ans++; if(ans==1)cout<<x<<" = "<<y2<<" x "<<z2; else cout<<endl<<x<<" = "<<y2<<" x "<<z2; } } for(i=1;i<10;i++){ if(a[i]==0){ b[cur+1]=i; a[i]=1; dfs(cur+1); a[i]=0; } } } int main() { dfs(0); return 0; }
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题1.6 (C语言代码)浏览:694 |
【魔板】 (C++代码)(时间超限,希望会的帮我改正一下)浏览:738 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:262 |
C语言程序设计教程(第三版)课后习题9.10 (C语言代码)浏览:819 |
sizeof的大作用 (C语言代码)浏览:1448 |
C语言程序设计教程(第三版)课后习题9.3 (C语言代码)浏览:593 |
数列排序 (C语言代码)浏览:606 |
拆分位数 (C语言代码)浏览:514 |
C语言程序设计教程(第三版)课后习题8.6 (C语言代码)浏览:585 |
1392题解(大数相加)浏览:601 |