青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

A Za, A Za, Fighting...

堅信:勤能補拙

PKU 3373 Changing Digits

問題:
http://acm.pku.edu.cn/JudgeOnline/problem?id=3373

參考:
http://blog.csdn.net/logic_nut/archive/2009/10/29/4740951.aspx
http://iaml.is-programmer.com/posts/8249.html (這個應該是SYSU的哈哈,里面有西西里)

思路:
這個題是真不會做,即使是看別人代碼都看了快兩天,艾...

首先要解決的問題是如何求大數的模(這里大數用字符串表示)?
我們知道對于取模運算有: (a+b)%k = ((a%k)+(b%k))%k
                                     (ab)%k = ((a%k)(b%k))%k
對于0-9的每個數,可以將其在個、十、百、千...位時模k的結果保存到一張表中: mod_arr
這樣,修改這個大數的任何一位而模k的新結果可以在O(1)時間內取得 
 1 char num[MAX_LEN];
 2 int hash[MAX_MOD];
 3 int mod_arr[MAX_LEN][10];
 4 int k, len, tmp[MAX_LEN], tmp2[MAX_LEN], start_mod;
 5 int head, tail;
 6 struct EACH {
 7     int digits[MAX_LEN];
 8     int remainder;
 9     int index;
10 } queue[MAX_MOD];
11 
12 void
13 init()
14 {
15     int i, j;
16     len = strlen(num);
17     for(j=0; j<10; j++)
18         mod_arr[0][j] = j%k;
19     for(i=1; i<len; i++)
20         for(j=0; j<10; j++)
21             mod_arr[i][j] = (mod_arr[i-1][j]*10)%k;
22     start_mod = 0;
23     for(i=0; i<len; i++) {
24         tmp[i] = tmp2[i] = num[len-i-1]-'0';
25         start_mod += (mod_arr[i][num[len-i-1]-'0']);
26     }
27     start_mod %= k;
28     head = -1;
29     tail = 0;
30     memset(hash, 0sizeof(hash));
31     memset(queue, 0sizeof(queue));
32 }

第一篇參考鏈接里是用DFS來做的,可惜我對于其中用于記憶化搜索的remember數組始終不理解,結果TLE
更加容易理解的方案是BFS,每次擴展改變一位數字
使用BFS的問題是如何判重?參考第二篇文章(繁瑣的C++語法,沒認真看呵呵),使用余數判重,其實還不是太理解

代碼:
 1 void
 2 bfs()
 3 {
 4     int i, j, t, cur_rem, cur_index;
 5     queue[tail].remainder = start_mod;
 6     memcpy(queue[tail].digits, tmp, sizeof(int)*len);
 7     queue[tail].index = len-1;
 8     hash[start_mod] = 1;
 9     while(head < tail) {
10         ++head;
11         cur_rem = queue[head].remainder;
12         cur_index = queue[head].index;
13         memcpy(tmp, queue[head].digits, sizeof(int)*len);
14         if(cur_rem == 0) {
15             for(i=len-1; i>=0; i--)
16                 printf("%d", tmp[i]);
17             printf("\n");
18             return;
19         }
20         /* changing digits: from least (smaller than itself) */
21         for(i=cur_index; i>=0; i--) {
22             for(j=0; j<tmp2[i]; j++) {
23                 if(i==len-1 && j==0)
24                     continue;
25                 t = cur_rem + mod_arr[i][j] - mod_arr[i][tmp2[i]] + k; /* O(1) to find the new remainder */
26                 t = t % k;
27                 tmp[i] = j;
28                 if(!hash[t]) {
29                     ++tail;
30                     queue[tail].remainder = t;
31                     queue[tail].index = i-1;
32                     memcpy(queue[tail].digits, tmp, sizeof(int)*len);
33                     hash[t] = 1;
34                 }
35             }
36             tmp[i] = tmp2[i];
37         }
38         /* changing digits: to max (greater than itself) */
39         for(i=0; i<=cur_index; i++) {
40             for(j=tmp2[i]+1; j<10; j++) {
41                 t = cur_rem + mod_arr[i][j] - mod_arr[i][tmp2[i]] + k;
42                 t = t % k;
43                 tmp[i] = j;
44                 if(!hash[t]) {
45                     ++tail;
46                     queue[tail].remainder = t;
47                     queue[tail].index = i-1;
48                     memcpy(queue[tail].digits, tmp, sizeof(int)*len);
49                     hash[t] = 1;
50                 }
51                 tmp[i] = tmp2[i];
52             }
53         }
54     }
55 }

posted on 2010-08-02 12:46 simplyzhao 閱讀(290) 評論(0)  編輯 收藏 引用 所屬分類: B_搜索

導航

<2011年10月>
2526272829301
2345678
9101112131415
16171819202122
23242526272829
303112345

統計

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美成人精品不卡视频在线观看| 午夜伦理片一区| 久久精品国产一区二区电影| 亚洲在线视频网站| 99xxxx成人网| 亚洲精品一区久久久久久 | 在线中文字幕日韩| 亚洲精品久久久久久久久久久| 伊人伊人伊人久久| 亚洲成人在线| 亚洲肉体裸体xxxx137| 日韩视频在线你懂得| 夜夜狂射影院欧美极品| 亚洲深夜福利在线| 亚洲一区二区综合| 久久久久成人网| 欧美14一18处毛片| avtt综合网| 欧美一区激情| 久久蜜桃资源一区二区老牛 | 国产美女精品视频| 国产欧美亚洲精品| 亚洲国产成人av好男人在线观看| 亚洲日本欧美天堂| 欧美专区在线| 91久久综合亚洲鲁鲁五月天| 日韩视频在线一区二区| 亚洲图片欧洲图片av| 久久嫩草精品久久久精品| 欧美日韩免费在线| 在线精品国产欧美| 欧美专区日韩视频| 欧美成人午夜免费视在线看片| 亚洲国产成人久久综合| 国产精品99久久久久久宅男| 久久精品人人做人人综合| 欧美福利影院| 激情一区二区三区| 亚洲欧美日韩成人| 亚洲国产一区二区精品专区| 欧美一级黄色网| 欧美性大战久久久久| 亚洲国产欧美久久| 久久久久久午夜| 亚洲一级黄色av| 欧美精品一区二区三区高清aⅴ| 永久免费精品影视网站| 欧美在线一二三四区| 99亚洲精品| 暖暖成人免费视频| 永久555www成人免费| 久久琪琪电影院| 亚洲欧美影院| 国产精品日韩欧美大师| 亚洲视频在线观看三级| 亚洲国产美女久久久久| 久热re这里精品视频在线6| 国产字幕视频一区二区| 欧美在线一级视频| 午夜在线一区| 国产午夜一区二区三区| 欧美一区二区三区在线播放| 亚洲影院色无极综合| 国产精品免费福利| 性久久久久久久| 欧美一区二区私人影院日本 | 久久综合福利| 欧美一区二区三区四区高清| 国产日韩av高清| 久久经典综合| 欧美专区第一页| 在线国产亚洲欧美| 亚洲激情电影中文字幕| 欧美成人日本| 正在播放亚洲一区| 国产精品99久久不卡二区| 国产精品白丝av嫩草影院| 香蕉久久一区二区不卡无毒影院| 亚洲一区二区三区高清 | 中日韩高清电影网| 中文一区二区| 一区在线视频观看| 亚洲电影毛片| 欧美视频专区一二在线观看| 性欧美8khd高清极品| 亚洲国产一区二区视频| 亚洲麻豆国产自偷在线| 欧美欧美天天天天操| 亚洲一级在线观看| 亚洲综合首页| 樱桃成人精品视频在线播放| 亚洲黄色片网站| 国产精品日本| 男人的天堂成人在线| 欧美精品色网| 欧美在线资源| 欧美~级网站不卡| 午夜精品理论片| 蜜臀av性久久久久蜜臀aⅴ| 亚洲欧美一区二区激情| 麻豆精品网站| 欧美制服丝袜第一页| 欧美成人免费在线观看| 久久成人一区| 欧美日韩亚洲国产一区| 久热成人在线视频| 国产精品久久国产愉拍| 欧美成人一区二免费视频软件| 欧美日本免费| 鲁鲁狠狠狠7777一区二区| 国产精品黄色在线观看| 亚洲国产视频直播| 在线高清一区| 午夜影院日韩| 性xx色xx综合久久久xx| 欧美日韩国产一中文字不卡 | 黄色成人在线网站| 在线一区视频| 亚洲免费观看| 久久亚洲综合色一区二区三区| 亚洲欧美另类中文字幕| 欧美激情亚洲精品| 欧美大片va欧美在线播放| 国产日韩欧美在线一区| 夜夜嗨av一区二区三区| 日韩亚洲综合在线| 麻豆国产精品va在线观看不卡| 久久综合精品国产一区二区三区| 国产精品视频一| 在线视频欧美日韩| 亚洲一二三区在线| 欧美日韩午夜激情| 日韩一级不卡| 亚洲图中文字幕| 欧美日韩在线一区| 这里只有精品电影| 亚洲欧美日韩成人| 国产精品外国| 在线一区欧美| 亚洲欧美影音先锋| 国产欧美日韩一区二区三区| 亚洲伊人网站| 久久黄色小说| 亚洲成在线观看| 欧美bbbxxxxx| 亚洲国内自拍| 在线视频欧美精品| 欧美午夜精品久久久久久久| 亚洲欧美变态国产另类| 亚洲精品一二三区| 欧美岛国激情| 亚洲三级影院| 亚洲一区二区三区在线看| 欧美三区免费完整视频在线观看| 99国产精品久久久| 午夜精品在线看| 国模私拍视频一区| 乱中年女人伦av一区二区| 亚洲韩日在线| 亚洲性线免费观看视频成熟| 国产美女精品| 欧美gay视频激情| 一区二区三区**美女毛片| 欧美一区午夜精品| 亚洲国产婷婷| 国产精品久久7| 久久久久久久97| 亚洲日本国产| 欧美亚洲三区| 亚洲激情在线激情| 国产精品男女猛烈高潮激情 | 亚洲福利免费| 亚洲女优在线| 亚洲国产精品va| 国产精品国产精品| 久久久国产精品一区二区中文| 亚洲国产精品久久久久秋霞不卡| 亚洲欧美日韩一区| 伊人婷婷欧美激情| 国产精品第三页| 久久亚洲一区| 亚洲一区二区动漫| 亚洲国产成人在线视频| 性亚洲最疯狂xxxx高清| 亚洲精品看片| 国产日韩一区二区三区| 欧美日韩国产精品一区| 久久精品亚洲一区二区三区浴池| 亚洲精品中文字幕有码专区| 久久婷婷av| 午夜日韩av| 一区二区三区www| 亚洲国产精品久久久久| 国产精品久久一区二区三区| 猫咪成人在线观看| 久久精品国产精品亚洲| 亚洲视频综合在线| 欧美激情亚洲另类| 麻豆成人av| 久久综合久久综合这里只有精品 |