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

這是《算法設計與分析》教材上的一道題,我們老師布置的第一道題。說的是統計出一本給定頁碼書中從0~9各個數字出現的次數,頁碼最高不差過10e9。
窮舉法是很容易想到的,不過當輸入過大時很耗時間。因此應該總結規律。
#include<stdio.h>
#include
<string.h>
#include
<stdlib.h>
#include
<math.h>
#define LEN 20
int bs[] = {0120300400050000600000700000080000000900000000};
int BS = 1111111111;
void StrtoNum(char *str, int *num)
{
    
int i, len;
    len 
= strlen(str);
    
*num = 0;
    
for(i = 0; i < len; i++)
        
*num = *num * 10 + str[i] - '0';
}

int Pow(int a, int b)
{
    
int i, t;
    t 
= a;
    
for(i = 0; i < b - 1; i++)
        t 
*=a;
    
return t;
}

int GetMod(int a)
{
    
return BS % Pow(10, a);
}

int main()
{
    
int i, j;
    
int nb;// now bit
    char nums[LEN];
    
int num;
    
int rs[10];// result 
    int len;
    
int mh;//most high 
    int nt;
    
while(gets(nums) != NULL)
    
{
        memset(rs, 
0sizeof(rs));
        len 
= strlen(nums);
        StrtoNum(nums, 
&num);
        
//
        
//printf("num = %d\n", num);
        
//
        mh = nums[len - 1- '0';
        
for(i = 0; i <= mh; i++)//init the lowest bit
            rs[i] = 1;
        
for( i = 1; i < len; i++)
        
{
            nb 
= len - i -1;
            mh 
= nums[nb] - '0';
            StrtoNum(
&nums[nb + 1], &nt);
            
//
            
//printf("mh = %d nt = %d\n", mh, nt);
            
//
            rs[mh] += nt + 1;//@2, mh mh
            for(j = 0; j < mh; j++)//@2 others
            {
                rs[j] 
+= Pow(10, i); 
            }

            
for(j = 0; j < 10; j++)//@1
            {
                rs[j] 
+= mh * bs[i];
            }
            
        }

        rs[
0-= GetMod(len);
        
for(i = 0; i < 10; i++)
            printf(
"%d %d\n", i, rs[i]);
    }

    
//getchar();
}

統計出只有一位數的情況是很簡單的,我們來當在統計好的一個數字前面再加上位數時統計結果會怎么增加。我們可以把這個增加的值看做兩部分,一部分是因高位增加導致地位數的取值范圍增大而導出的,另一部分是高位本身產生的。兩方面的計算都有規律可循。要特別注意0的計算。
請注意庫函數pow()的返回值為double,轉換為int時會有精度丟失(調試中的表現為無論數據多大,結果總跟標準答案相差1),因此這里特地寫了一個Pow()函數做返回值為int的乘方計算。
posted on 2012-03-08 19:38 小鼠標 閱讀(1128) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2013年3月>
242526272812
3456789
10111213141516
17181920212223
24252627282930
31123456

常用鏈接

隨筆分類(111)

隨筆檔案(127)

friends

最新評論

  • 1.?re: 線段樹
  • 是這個樣子的,所以在OJ有時候“卡住”了也不要太灰心,沒準真的不是自己的原因呢。
    加油,祝你好運啦!
  • --小鼠標
  • 2.?re: 線段樹
  • 對于編程競賽來說,Java所需時間一般為C/C++的兩倍。合理的競賽給Java的時間限制是給C/C++的兩倍。
  • --傷心的筆
  • 3.?re: poj1273--網絡流
  • 過來看看你。
  • --achiberx
  • 4.?re: (轉)ubuntu11.10無法啟動無線網絡的解決方法
  • 膜拜大神。。查了一個下午資料終于在這里解決了問題。。神牛說的區域賽難道是ACM區域賽。。?
  • --Hang
  • 5.?re: 快速排序、線性時間選擇
  • 博主,謝謝你的文章。你的方法可以很好的處理分區基準在數組中重復的情況,書上的方法遇到這種輸入會堆棧溢出。書上給出了解釋但給的方法貌似不簡潔。
  • --lsxqw2004

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            激情一区二区三区| 9色精品在线| 久久久久久国产精品mv| 午夜久久影院| 黑丝一区二区| 91久久黄色| 欧美日韩少妇| 久久久99爱| 欧美国产精品劲爆| 中文一区字幕| 久久av一区二区三区漫画| 精品69视频一区二区三区| 亚洲国产日韩欧美在线99 | 久久高清免费观看| 欧美在线视频一区二区三区| 在线色欧美三级视频| 亚洲黄色av一区| 欧美视频一区二区三区在线观看 | 国产欧美三级| 亚洲国产成人午夜在线一区| 国产精品成人在线| 久久综合九色综合欧美就去吻| 欧美电影免费观看高清完整版| 亚洲一区观看| 久久中文欧美| 欧美一区激情| 欧美精品二区| 蜜臀99久久精品久久久久久软件| 欧美日韩国产成人| 免费久久99精品国产自| 欧美四级在线观看| 久久综合伊人| 国产精品国产自产拍高清av王其 | 噜噜噜在线观看免费视频日韩| 欧美了一区在线观看| 久久久久久一区二区三区| 欧美日韩高清在线| 免费久久99精品国产自在现线| 欧美午夜一区二区三区免费大片| 久久躁日日躁aaaaxxxx| 国产精品高潮呻吟久久| 亚洲电影观看| 在线看无码的免费网站| 亚洲欧美日韩综合国产aⅴ| 一区二区不卡在线视频 午夜欧美不卡在 | 亚洲视频精品| 亚洲视频免费观看| 欧美精品日韩| 欧美成人免费一级人片100| 国产亚洲激情视频在线| 亚洲午夜精品一区二区三区他趣| 亚洲区国产区| 嫩草成人www欧美| 麻豆成人综合网| 国内一区二区三区在线视频| 亚洲欧洲av一区二区| 亚洲欧美日韩一区| 欧美午夜视频| 在线一区二区日韩| 亚洲一二三区精品| 欧美日韩中文字幕在线视频| 亚洲美女区一区| 一区二区高清视频| 欧美日韩亚洲一区二区| 日韩写真在线| 亚洲综合色视频| 国产欧美高清| 欧美中文字幕在线观看| 久久久久成人网| 一区在线电影| 免费h精品视频在线播放| 欧美成人有码| 99精品国产在热久久婷婷| 欧美国产在线电影| 一片黄亚洲嫩模| 午夜精品久久99蜜桃的功能介绍| 国产精品久久久久9999| 亚洲综合不卡| 麻豆精品视频在线观看| 亚洲日本无吗高清不卡| 欧美日韩精品二区第二页| 亚洲视频精品| 久久一区激情| 一本久久综合亚洲鲁鲁| 国产精品ⅴa在线观看h| 亚洲欧美日韩精品久久亚洲区| 久久全球大尺度高清视频| 亚洲黄色尤物视频| 欧美日韩精品免费观看视频| 亚洲欧美清纯在线制服| 欧美大片在线观看一区| 一区二区三区波多野结衣在线观看| 国产精品国产a| 久久久久九九视频| 亚洲精品在线视频观看| 久久www成人_看片免费不卡| 亚洲第一狼人社区| 欧美三级特黄| 久久伊人精品天天| 日韩网站免费观看| 久久久亚洲人| 在线视频亚洲欧美| 黄色影院成人| 国产精品久久久久久模特 | 激情成人中文字幕| 奶水喷射视频一区| 午夜精品久久久久久久久久久久久| 欧美高清你懂得| 性色av一区二区怡红| 亚洲精品综合| 激情综合网址| 国产精品一区在线观看| 欧美ed2k| 久久久久国产精品午夜一区| 在线中文字幕一区| 亚洲国产日韩欧美在线99| 久久精品首页| 亚洲一级特黄| 夜夜爽99久久国产综合精品女不卡| 国产欧美一区二区三区久久| 欧美日韩福利视频| 欧美成人精品在线视频| 久久精品亚洲| 欧美一区二区三区在线看| 亚洲视频在线看| 亚洲清纯自拍| 亚洲国产毛片完整版| 另类亚洲自拍| 快she精品国产999| 久久精品一区四区| 欧美一区二区三区免费视频| 亚洲深夜福利网站| 一区二区精品国产| 一区二区三区国产盗摄| 亚洲人成人77777线观看| 亚洲第一福利社区| 亚洲大胆人体在线| 亚洲成人在线视频网站| 激情婷婷久久| 亚洲国产成人tv| 亚洲电影视频在线| 亚洲国产成人在线播放| 在线观看一区视频| 亚洲国产高清在线观看视频| 亚洲高清在线视频| 亚洲精品乱码久久久久久蜜桃91 | 亚洲美洲欧洲综合国产一区| 亚洲国产美女| 最新国产精品拍自在线播放| 亚洲欧洲三级| 亚洲靠逼com| 亚洲一区bb| 午夜日韩激情| 久久久久女教师免费一区| 久久久久久久综合| 模特精品裸拍一区| 亚洲激情小视频| 亚洲视频在线观看视频| 欧美一区二区黄| 毛片精品免费在线观看| 欧美福利影院| 国产精品家教| 黄色成人91| 亚洲美女尤物影院| 性做久久久久久| 欧美 日韩 国产 一区| 亚洲激情视频网| 国产精品99久久不卡二区| 小黄鸭视频精品导航| 久久在线精品| 欧美视频一区二区在线观看| 国产欧美视频一区二区三区| 亚洲韩国青草视频| 亚洲综合成人在线| 欧美xx视频| 亚洲午夜精品一区二区| 久久偷看各类wc女厕嘘嘘偷窃| 欧美理论在线| 国内视频精品| 亚洲视频观看| 蜜乳av另类精品一区二区| 亚洲精品一区在线| 久久精品青青大伊人av| 欧美日韩在线播放三区| 尤妮丝一区二区裸体视频| 亚洲综合色激情五月| 欧美www视频| 亚洲欧美乱综合| 欧美剧在线免费观看网站| 国产自产在线视频一区| 亚洲无人区一区| 欧美成人免费va影院高清| 亚洲一区999| 欧美经典一区二区三区| 国产一区二区久久久| 亚洲欧美高清| 99在线热播精品免费| 老司机精品导航| 黄色亚洲网站| 久久精品动漫|