Time Limit: 1 second

Memory Limit: 128 MB

【问题描述】

Sramoc(K,M)表示用数字0,1,2,。。。,K-1组成的自然数中能被M整除的最小数。给定K,M,求Sramoc(K,M)。

例如,K=2,M=7时,Sramoc(K,M)=1001。

【输入格式】

输入文件第一行为两个整数K,M,满足2<=k<=10,1<=m<=1000。

【输出格式】

输出文件包含Sramoc(K,M)的值。

Sample Input

2 7

Sample Output

1001

【题目链接】:http://noi.qz5z.com/viewtask.asp?id=t085

【题意】



按照数据,不一定要用满k个数字,可以只用一部分.

【题解】



这个用同余率来搞吧;

每次增加一位的时候只要知道前n-1位的模m的值就好了;

然后*10+新加上的数字然后再对m取模;就是n位数的模m值了;

然后可以用一个二维数组bo[i][j]来判重,表示最后一位数字为i,余数为j的情况有没有出现过;

用广搜吧;

加上那个判重;

很容易写出程序;

程序在队列的基础上写了个递归的输出过程;

这样就不用把整个数字都记录下来了(这个数字多大都没关系了);



【完整代码】

  1. #include <cstdio>
  2. #include <algorithm>
  3. #include <cmath>
  4. using namespace std;
  5. #define lson l,m,rt<<1
  6. #define rson m+1,r,rt<<1|1
  7. #define LL long long
  8. #define rep1(i,a,b) for (int i = a;i <= b;i++)
  9. #define rep2(i,a,b) for (int i = a;i >= b;i--)
  10. #define mp make_pair
  11. #define pb push_back
  12. #define fi first
  13. #define se second
  14. #define rei(x) scanf("%d",&x)
  15. #define rel(x) scanf("%I64d",&x)
  16. typedef pair<int,int> pii;
  17. typedef pair<LL,LL> pll;
  18. const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
  19. const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
  20. const double pi = acos(-1.0);
  21. const int MAXN = 110;
  22. struct abc
  23. {
  24. int pre,num,last;
  25. };
  26. int k,m,l,r;
  27. abc dl[500000];
  28. bool bo[10][2000];
  29. void output_ans(int now)
  30. {
  31. if (now==0)
  32. return;
  33. output_ans(dl[now].pre);
  34. printf("%d",dl[now].last);
  35. }
  36. int main()
  37. {
  38. //freopen("F:\\rush.txt","r",stdin);
  39. rei(k);rei(m);
  40. rep1(i,1,k-1)
  41. {
  42. if (i%m==0)
  43. {
  44. printf("%d\n",i);
  45. return 0;
  46. }
  47. if (bo[i][i%m]) continue;
  48. bo[i][i%m] = true;
  49. abc temp;
  50. temp.pre = 0;
  51. temp.num = i%m;
  52. temp.last = i;
  53. dl[++r] = temp;
  54. }
  55. l = 0;
  56. while (l < r)
  57. {
  58. abc tou = dl[++l];
  59. int now = tou.num;
  60. rep1(i,0,k-1)
  61. {
  62. int rest = (now*10+i)%m;
  63. if (!bo[i][rest])
  64. {
  65. bo[i][rest] = true;
  66. abc temp1;
  67. temp1.num = rest;
  68. temp1.pre = l;
  69. temp1.last = i;
  70. dl[++r] = temp1;
  71. if (rest==0)
  72. {
  73. output_ans(r);
  74. return 0;
  75. }
  76. }
  77. }
  78. }
  79. return 0;
  80. }

【t085】Sramoc问题的更多相关文章

  1. 洛谷P1602 Sramoc问题 题解报告【同余+bfs】

    题目描述 话说员工们整理好了筷子之后,就准备将快餐送出了,但是一看订单,都傻眼了:订单上没有留电话号码,只写了一个sramoc(k,m)函数,这什么东西?什么意思?于是餐厅找来了资深顾问团的成员,YQ ...

  2. 洛谷P1602 Sramoc问题

    P1602 Sramoc问题 题目描述 话说员工们整理好了筷子之后,就准备将快餐送出了,但是一看订单,都傻眼了:订单上没有留电话号码,只写了一个sramoc(k,m)函数,这什么东西?什么意思?于是餐 ...

  3. 洛谷——P1602 Sramoc问题

    P1602 Sramoc问题 $bfs$搜索 保证第一个搜到的符合条件的就是最小的 #include<bits/stdc++.h> #define N 110000 using names ...

  4. 洛谷 P1602 Sramoc问题

    题目描述 话说员工们整理好了筷子之后,就准备将快餐送出了,但是一看订单,都傻眼了:订单上没有留电话号码,只写了一个sramoc(k,m)函数,这什么东西?什么意思?于是餐厅找来了资深顾问团的成员,YQ ...

  5. 洛谷 1602 Sramoc问题

    Description 话说员工们整理好了筷子之后,就准备将快餐送出了,但是一看订单,都傻眼了:订单上没有留电话号码,只写了一个sramoc(k,m)函数,这什么东西?什么意思?于是餐厅找来了资深顾问 ...

  6. luogu P1602 Sramoc问题

    嗯...这篇题解写的原因是一位大佬网友问我的题 本蒟蒻为了纪念下这一刻,就写了 我只会写一写基本思路,经不起推敲 还是大家凑活看吧 重点来了 在bfs时,队列里的每个元素由一个高精度的数和那个数模m的 ...

  7. 洛谷1602 Sramoc问题

      刚看到这道题的时候感觉像spfa. 然后发现其实bfs就可以做了. //Serene #include<algorithm> #include<iostream> #inc ...

随机推荐

  1. Java连接Neo4j的两种方式

    1.Neo4j数据库的两种方式 Neo4j可以以两种方式运行: Java应用程序中的嵌入式数据库 通过REST的独立服务器 不管哪一种方式,这个选择不会影响查询和使用数据库的方式. 它是由应用程序的性 ...

  2. 怎么用PHP+sqlite3验证登录用户名和密码

    Session:在计算机中,尤其是在网络应用中,称为“会话控制”.Session 对象存储特定用户会话所需的属性及配置信息.这样,当用户在应用程序的 Web 页之间跳转时,存储在 Session 对象 ...

  3. JavaScript--预解析在IE存在的问题

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  4. Nginx设置静态页面压缩和缓存过期时间的方法 (转)

    使用nginx服务器的朋友可能都知道需要设置html静态页面缓存与页面压缩与过期时间的设置了,下面我来给各位同学介绍一下配置方法,包括对ico,gif,bmp,jpg,jpeg,swf,js,css, ...

  5. txt改后缀弹窗表白

    one. 打开新建的文本文件,输入字符:msgbox("此处可替换成你想要出现的文字"),括号和引号是英文状态下的标点.(可根据自己的需要输入多行) two. 保存新建的文本文件, ...

  6. js cookies 的写入、读取、删除

    //写cookies //escape() 函数可对字符串进行编码,这样就可以在所有的计算机上读取该字符串.function setCookie(name,value) {     var Days ...

  7. 数组map用法总结

    数组中,map方法,指的是是数组的映射. map基本语法如下:function回调支持3个参数,第1个是遍历的数组内容:第2个是对应的数组索引,第3个是数组本身. map方法的作用不难理解,“映射”嘛 ...

  8. 【JZOJ4887】【NOIP2016提高A组集训第13场11.11】最大匹配

    题目描述 mhy12345学习了二分图匹配,二分图是一种特殊的图,其中的点可以分到两个集合中,使得相同的集合中的点两两没有连边. 图的"匹配"是指这个图的一个边集,里面的边两两不存 ...

  9. AtCoder Regular Contest 084 C - Snuke Festival【二分】

    C - Snuke Festival ....最后想到了,可是不应该枚举a[],这样要二重循环,而应该枚举b[],这样只需一重循环... #include<iostream> #inclu ...

  10. 详解 CALayer 和 UIView 的区别和联系

    http://www.cocoachina.com/ios/20150828/13244.html 作者:@武蕴牛x 授权本站转载. 前言 前面发了一篇iOS 面试的文章,在说到 UIView 和 C ...