UVA 725 Division(hash+枚举)
题目大意:
就是说给你一个abcde/fghij = n的表达式,给你一个n,让你求出有多少个这样的式子。
解题思路:
最为简单的枚举了,要注意到我们只需要枚举出来fghij就可以了,因为abcde=fghij*n,这样的话,时间复杂度由10!就
降低到了5!,在枚举结束后,我们只需要判断0-9这些数字是否都出现了且仅出现一次即可。然后对于超过5位的数字,我们
直接break掉。
这道题的输出一定要注意那个前导0,,一开始忘记了,WA了两次,然后果断用setw(5)和setfill('0')给搞定了。
这条语句也是可以搞定的 printf("%d / %05d = %d\n",tt,t,n);
代码:
# include<cstdio> # include<iostream> # include<algorithm> # include<functional> # include<cstring> # include<string> # include<cstdlib> # include<iomanip> # include<numeric> # include<cctype> # include<cmath> # include<ctime> # include<queue> # include<stack> # include<list> # include<set> # include<map> using namespace std; const double PI=4.0*atan(1.0); typedef long long LL; typedef unsigned long long ULL; # define inf 999999999 int n; int num[10]; int check ( int x,int y ) { memset(num,0,sizeof(num)); int a = x; int b = y; for ( int i = 0;i < 5;i++ ) { num[a%10]++; num[b%10]++; a/=10; b/=10; } for ( int i = 0;i < 10;i++ ) { if ( num[i]!=1 ) return 0; } return 1; } int main(void) { int icase = 1; while ( cin>>n ) { if ( n==0 ) break; if ( icase > 1 ) cout<<endl; int flag = 0; for ( int t = 1234;;t++ ) { int tt = t*n; if ( tt >= 100000 ) break; if ( check(tt,t) ) { flag = 1; printf("%d / %05d = %d\n",tt,t,n); //printf("%d / %d = %d\n",tt,t,n); } } if ( !flag ) { printf("There are no solutions for %d.\n",n); } icase++; } return 0; }
分类:
算法设计--暴力
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 《HelloGitHub》第 106 期
· 数据库服务器 SQL Server 版本升级公告
· 深入理解Mybatis分库分表执行原理
· 使用 Dify + LLM 构建精确任务处理应用