博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ZOJ 3596Digit Number(BFS+DP)
阅读量:6683 次
发布时间:2019-06-25

本文共 2861 字,大约阅读时间需要 9 分钟。

一道比较不错的BFS+DP题目

题意很简单,就是问一个刚好包含m(m<=10)个不同数字的n的最小倍数。

 

很明显如果直接枚举每一位是什么这样的话显然复杂度是没有上限的,所以需要找到一个状态表示方法:

令F[i][j] 表示已经用了 i (二进制压位表示)用了 i 这些数字,且余数j为的状态,枚举时直接枚举当前位,那么答案明显就是F[m][0]

我这里将状态i, j存在了一维空间里,即 i * 1000 + j表示,实际上用一个结构体存队列里的点,用二维数组标记状态也是可行的。

1 #include   2 #include 
3 #include
4 #include
5 #include
6 #include
7 #include
8 #include
9 #include
10 #include
11 #include
12 #include
13 #include
14 using namespace std; 15 #define INF 0x3f3f3f3f 16 #define inf (-((LL)1<<40)) 17 #define lson k<<1, L, mid 18 #define rson k<<1|1, mid+1, R 19 #define mem0(a) memset(a,0,sizeof(a)) 20 #define mem1(a) memset(a,-1,sizeof(a)) 21 #define mem(a, b) memset(a, b, sizeof(a)) 22 #define FIN freopen("in.txt", "r", stdin) 23 #define FOUT freopen("out.txt", "w", stdout) 24 #define rep(i, a, b) for(int i = a; i <= b; i ++) 25 26 template
T CMP_MIN(T a, T b) { return a < b; } 27 template
T CMP_MAX(T a, T b) { return a > b; } 28 template
T MAX(T a, T b) { return a > b ? a : b; } 29 template
T MIN(T a, T b) { return a < b ? a : b; } 30 template
T GCD(T a, T b) { return b ? GCD(b, a%b) : a; } 31 template
T LCM(T a, T b) { return a / GCD(a,b) * b; } 32 33 //typedef __int64 LL; 34 typedef long long LL; 35 const int MAXN = 110000; 36 const int MAXM = 20010; 37 const double eps = 1e-4; 38 //LL MOD = 987654321; 39 40 int t, n, m, x; 41 struct Node { 42 bool vis; 43 char num; 44 int pre, cnt; 45 }s[(1<<10) * 1100]; 46 char ans[110000], d[110000]; 47 48 int bfs() 49 { 50 queue
q; 51 q.push(0); 52 while(!q.empty()) { 53 int head = q.front();q.pop(); 54 rep (i, 0, 9) { 55 if(head == 0 && i == 0) continue; 56 int mod = (head % 1000 * 10 + i) % n; 57 int tail = ((head / 1000) | (1 << i)) * 1000 + mod; 58 if(s[tail].vis) 59 continue; 60 s[tail].vis = true; 61 s[tail].num = i + '0'; 62 s[tail].pre = head; 63 s[tail].cnt = s[head].cnt + ((head / 1000) & (1 << i) ? 0 : 1); 64 if(s[tail].cnt == m && mod == 0) { 65 return tail; 66 } 67 if(s[tail].cnt <= m) q.push(tail); 68 } 69 } 70 return 0; 71 } 72 73 //calc a / b 74 char* divide(char *a, int len, int b) { 75 mem0(d); 76 int i = 0, cur = 0, l = 0; 77 while(cur < b && i < len) { 78 cur = cur * 10 + a[i++] - '0'; 79 } 80 d[l++] = cur / b + '0'; 81 while(i < len) { 82 cur = cur % b * 10 + a[i++] - '0'; 83 d[l++] = cur / b + '0'; 84 } 85 return d; 86 } 87 88 void print(int ed) { 89 int len = 0; 90 mem0(ans); 91 while(ed) { 92 ans[len++] = s[ed].num; 93 ed = s[ed].pre; 94 } 95 reverse(ans, ans + len); 96 printf("%s=%d*%s\n", ans, n, divide(ans, len, n)); 97 } 98 99 int main()100 {101 //FIN;102 while(cin >> t) while(t--) {103 cin >> n >> m;104 mem0(s);105 if( !(x = bfs()) ) {106 puts("Impossible");107 }108 else {109 print(x);110 }111 }112 return 0;113 }

 

转载于:https://www.cnblogs.com/gj-Acit/p/4492762.html

你可能感兴趣的文章
sed工具扩展学习
查看>>
db4o 参考资料
查看>>
mysql生产环境___主从同步修复案例
查看>>
对Controller的单元测试
查看>>
人工智能无法挑战人心
查看>>
移动web 1px边框解决方案
查看>>
centos7.4 Rsync配置和触发备份
查看>>
Oracle12c 安装
查看>>
DX11之D3DXMatrixIdentity 函数
查看>>
四项重要标准 让金融机构评选合适的DDoS防护提供商
查看>>
iOS开发的插件和工具
查看>>
设置UIButton,UITextFild边框圆角(上半边或下半边)
查看>>
Python __init__.py 文件使用
查看>>
Spring源码-IOC容器(五)-Bean的初始化
查看>>
zookeeper原理
查看>>
我的友情链接
查看>>
有监视哨的顺序查找
查看>>
微信小程序开发之表单验证(WxValidate使用)
查看>>
Oracle DataBase 各种版本资源路径汇总
查看>>
缓存名称服务器
查看>>