国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

【t085】Sramoc問題

2019-11-14 09:37:20
字體:
來源:轉載
供稿:網友

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的情況有沒有出現過; 用廣搜吧; 加上那個判重; 很容易寫出程序; 程序在隊列的基礎上寫了個遞歸的輸出過程; 這樣就不用把整個數字都記錄下來了(這個數字多大都沒關系了); 【完整代碼】

#include <cstdio>#include <algorithm>#include <cmath>using namespace std;#define lson l,m,rt<<1#define rson m+1,r,rt<<1|1#define LL long long#define rep1(i,a,b) for (int i = a;i <= b;i++)#define rep2(i,a,b) for (int i = a;i >= b;i--)#define mp make_pair#define pb push_back#define fi first#define se second#define rei(x) scanf("%d",&x)#define rel(x) scanf("%I64d",&x)typedef pair<int,int> pii;typedef pair<LL,LL> pll;const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};const double pi = acos(-1.0);const int MAXN = 110;struct abc{ int PRe,num,last;};int k,m,l,r;abc dl[500000];bool bo[10][2000];void output_ans(int now){ if (now==0) return; output_ans(dl[now].pre); printf("%d",dl[now].last);}int main(){ //freopen("F://rush.txt","r",stdin); rei(k);rei(m); rep1(i,1,k-1) { if (i%m==0) { printf("%d/n",i); return 0; } if (bo[i][i%m]) continue; bo[i][i%m] = true; abc temp; temp.pre = 0; temp.num = i%m; temp.last = i; dl[++r] = temp; } l = 0; while (l < r) { abc tou = dl[++l]; int now = tou.num; rep1(i,0,k-1) { int rest = (now*10+i)%m; if (!bo[i][rest]) { bo[i][rest] = true; abc temp1; temp1.num = rest; temp1.pre = l; temp1.last = i; dl[++r] = temp1; if (rest==0) { output_ans(r); return 0; } } } } return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 长乐市| 姚安县| 万山特区| 肥西县| 若尔盖县| 平顺县| 沽源县| 黎平县| 濉溪县| 迁西县| 马尔康县| 丹东市| 浠水县| 额济纳旗| 河北区| 延吉市| 凤凰县| 新邵县| 鹤山市| 金华市| 隆林| 佛山市| 乐清市| 错那县| 聂拉木县| 玉田县| 昌平区| 招远市| 崇信县| 南丹县| 正宁县| 博湖县| 秦皇岛市| 温州市| 隆尧县| 樟树市| 沙洋县| 门源| 临朐县| 旌德县| 黄山市|