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

隨筆 - 40, 文章 - 0, 評論 - 19, 引用 - 0
數(shù)據(jù)加載中……

PKU 1001 Exponentiation

http://acm.pku.edu.cn/JudgeOnline/problem?id=1001

求高精度冪的題目,題目的難度在于處理如同 .00010 的輸入

和輸出的前導(dǎo)后導(dǎo)零的問題,還有小數(shù)點的位置可能在處理輸入時候被影響
寫了好久代碼,但是同學(xué)用JAVA只需要一會就能搞定了,郁悶...
附上AC代碼:

  1Source Code
  2
  3Problem: 1001  User: hongtaozhy 
  4Memory: 304K  Time: 0MS 
  5Language: G++  Result: Accepted 
  6
  7Source Code 
  8#include<stdio.h>
  9#include<string.h>
 10#include<math.h>
 11void reverse(char*str);
 12void multi(char*num1,char*num2,char*result);
 13    char a[100]; 
 14    char str[100];
 15    char sum[200];
 16    char tem[200];
 17    char tem2[100];
 18int main(){
 19    int flag;
 20    int n; 
 21    int key;
 22    int flag2;
 23    int kk;
 24//freopen("a.txt","r",stdin);
 25//freopen("a2.txt","w",stdout);
 26    while(scanf("%s%d",a,&n)==2){
 27    memset(str,0,sizeof(str));
 28    kk=0;
 29    flag=-1;
 30    flag2=6;
 31    int g=0;
 32    int j=0;
 33    int t = 0;
 34    if(a[0]=='.'){ g=1;}
 35    for(int i = 0 ; i < 6 ; i++){
 36    if(a[i]=='0'&&kk==0)continue;    
 37    kk=1;
 38    a[t++]=a[i];
 39    }

 40    a[t]='\0';
 41    
 42    if(a[0]=='.'{
 43    for(int i =strlen(a);i>=0;i--)
 44    a[i+1]=a[i];  
 45    a[0]='0';
 46    }
{
 47    int i;
 48    for(i=0 ; i < strlen(a);i++ )
 49    if(a[i]=='.'break;
 50    if(i==strlen(a)) {a[i]='.';a[i+1]='0';a[i+2]='\0';}}

 51
 52    for(int i=0;i<strlen(a);i++)
 53    if(a[i]=='.')  {  flag=i;kk=1;}
 54    else {
 55    if(a[i]=='0'&&flag!=-1&&flag2==strlen(a)) flag2=i;
 56    if(a[i]!='0'&&flag!=-1) flag2=strlen(a);
 57    str[j++]=a[i];      
 58    }
 
 59    
 60    int ne=strlen(a)-flag-1;
 61    for(j = strlen(str)-1 ; j >= 0 ; j-- ){
 62    if(str[j] == '0'&&ne--){
 63    str[j]='\0';
 64    }
    
 65    else  break;
 66    }

 67    flag=flag2-flag-1;
 68    //接入結(jié)束
 69    if(g==1)
 70    printf(".");
 71    memset(sum,0,sizeof(sum));
 72    memset(tem,0,sizeof(tem));
 73    memset(tem2,0,sizeof(tem2));
 74    key=0;
 75    sum[0]='1';
 76    sum[1]='\0';    
 77    for(int i=0; i < n ; i++)
 78    {     
 79          if(key!=1)
 80          key=1;
 81          strcpy(tem2,str);
 82          multi(sum,tem2,tem);
 83          memset(sum,0,sizeof(sum));
 84          memset(tem2,0,sizeof(tem2));
 85          }
     
 86          else{
 87          strcpy(tem2,str);
 88          key=0;
 89          multi(tem,tem2,sum);
 90          memset(tem,0,sizeof(tem));
 91          memset(tem2,0,sizeof(tem2));
 92          }

 93    }
 
 94    if(key==1)
 95                    for(int i = 0 ; tem[i] != '\0' ; i++ ){
 96                    if( tem[i] == '0' && i == 0 ) continue;
 97                   if(i==strlen(tem)-(flag*n)&&g!=1) printf(".");
 98                  printf("%c",tem[i]);
 99                    }

100    }

101    else{          
102                    for(int i = 0 ; sum[i] != '\0' ; i++ ){
103                    if( sum[i] == '0' && i == 0 ) continue;
104               if(i==strlen(sum)-(flag*n)&&g!=1) printf(".");
105                  printf("%c",sum[i]);
106                    }

107    }

108    printf("\n");       
109    }

110return 0;
111}

112void multi(char*num1,char*num2,char*result)
113{
114    int i,j,len1,len2,len;
115
116    len1=strlen(num1);
117    len2=strlen(num2);
118    reverse(num2);
119    reverse(num1);
120
121    for (i=0;i<len1;i++)
122        num1[i] -= '0';
123    for (i=0;i<len2;i++)
124        num2[i] -= '0';
125
126    for (i=0;i<len2;i++)
127        for (j=0;j<len1;j++)
128        {
129            len=i+j;
130            result[len] += num2[i]*num1[j];
131            result[len+1+= result[len]/10;
132            result[len] %= 10;
133        }

134    len=len1+len2-1;
135    for (i=0;i<len;i++)
136        result[i] += '0';
137    if (result[len]) result[len] += '0';
138    reverse(result);
139}

140
141void reverse(char*str)
142{
143    int i;
144    char c;
145    for (i=0;i<strlen(str)/2;i++)
146    {
147        c=str[i];
148        str[i]=str[strlen(str)-i-1];
149        str[strlen(str)-i-1]=c;
150    }

151}

152
153
154

posted on 2008-07-16 00:43 hadn't 閱讀(1682) 評論(4)  編輯 收藏 引用

評論

# re: PKU 1001 Exponentiation  回復(fù)  更多評論   

膜拜一下。。。。。
2008-07-19 12:34 | gong

# re: PKU 1001 Exponentiation  回復(fù)  更多評論   

- -||@gong
2008-07-19 12:36 | hadn't

# re: PKU 1001 Exponentiation  回復(fù)  更多評論   

so 長的代碼,還是沒有動手寫高精乘,害怕,呵呵
2008-07-20 10:33 | 未央

# re: PKU 1001 Exponentiation  回復(fù)  更多評論   

求高手指導(dǎo),我改了N遍,還是得到wrong answer!

這里貼不下,代碼詳見:
http://poj.org/showmessage?message_id=169793

或者把意見發(fā)到我郵箱(huowaa@gmail.com)也行,非常感謝
2012-02-26 06:47 | huowaa

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲福利视频免费观看| 亚洲午夜91| 久久视频这里只有精品| 最新69国产成人精品视频免费| 亚洲国产日韩欧美在线99| 欧美午夜影院| 欧美日韩亚洲在线| 欧美日韩一区二区视频在线 | 欧美电影免费观看| 久久电影一区| 久久夜精品va视频免费观看| 久久综合九色综合久99| 久久久亚洲欧洲日产国码αv| 先锋影音国产一区| 亚洲欧美日本另类| 欧美亚洲在线视频| 久久亚洲春色中文字幕| 欧美成人一区二区三区在线观看| 久久麻豆一区二区| 亚洲精品美女在线观看| 在线亚洲观看| 鲁大师成人一区二区三区| 欧美黑人国产人伦爽爽爽| 国产精品久久久久aaaa| 亚洲日本免费| 欧美mv日韩mv国产网站| 六月婷婷一区| 国产拍揄自揄精品视频麻豆| 亚洲成人在线免费| 欧美在线播放一区| 99re8这里有精品热视频免费| 亚洲欧美www| 欧美国产日韩一区| 国产欧美 在线欧美| 亚洲综合社区| 亚洲精品在线视频观看| 麻豆国产va免费精品高清在线| 国产噜噜噜噜噜久久久久久久久 | 欧美精品国产精品| 精品51国产黑色丝袜高跟鞋| 亚洲欧美日韩中文视频| 一区二区三区四区国产精品| 欧美国产视频在线| 久久精品亚洲国产奇米99| 亚洲午夜伦理| 夜夜夜精品看看| 欧美国产精品久久| 欧美国产日韩一区二区| 亚洲国产成人精品久久久国产成人一区| 中文日韩欧美| 亚洲在线成人精品| 国产亚洲精久久久久久| 久久天堂精品| 欧美a级一区二区| 亚洲一级黄色| 亚洲免费影院| 最新日韩精品| 亚洲视频在线观看| 亚洲美女性视频| 欧美日韩一区成人| 久久经典综合| 欧美经典一区二区| 久久精品视频免费播放| 欧美日韩成人一区二区| 久久男人资源视频| 欧美丝袜第一区| 亚洲国产成人高清精品| 国产精品香蕉在线观看| 亚洲激情视频在线播放| 国产欧美日韩综合一区在线播放| 亚洲第一黄网| 亚洲福利在线看| 久久av一区二区三区| 亚洲欧美国产一区二区三区| 欧美二区在线播放| 欧美激情视频一区二区三区免费| 国产精品一卡| 欧美在线一二三区| 久久久国产精品一区| 国产目拍亚洲精品99久久精品 | 女女同性精品视频| 国产精品久久久久永久免费观看| 欧美激情1区2区| 亚洲国语精品自产拍在线观看| 久久国产福利| 欧美高清在线视频| 亚洲免费不卡| 国产精品区一区二区三| 亚洲在线免费视频| 久久精品在线免费观看| 激情综合网址| 欧美日产在线观看| 亚洲欧美国产另类| 欧美日韩在线播放三区| 亚洲一区二区三区精品视频| 欧美在线视频免费观看| 尤物精品国产第一福利三区| 欧美激情一区二区三级高清视频| 亚洲人妖在线| 久久精品国产精品亚洲综合| 91久久精品国产| 欧美日韩卡一卡二| 亚洲欧美精品中文字幕在线| 快播亚洲色图| 亚洲午夜视频| 亚洲伦理在线免费看| 国产午夜精品久久久| 欧美日韩视频在线观看一区二区三区| 亚洲一区二区三区四区视频| 欧美黄免费看| 久久亚洲图片| 久久久一本精品99久久精品66| 亚洲字幕一区二区| 亚洲深夜av| 亚洲午夜在线观看视频在线| 亚洲国产欧美国产综合一区| 国产在线欧美日韩| 国产精品一区二区女厕厕| 欧美午夜电影一区| 欧美视频在线观看| 国产精品国产精品国产专区不蜜| 久久午夜电影| 欧美成人一区在线| 欧美区在线播放| 国产精品多人| 国产一区视频在线观看免费| 国产亚洲精品福利| 国产色爱av资源综合区| 国产欧美精品xxxx另类| 在线观看欧美| 一本大道久久a久久精二百| 亚洲一区二区三区四区五区午夜| 亚洲午夜在线视频| 一区二区三区国产在线| 一本色道久久综合精品竹菊| 一区二区欧美日韩| 久久午夜国产精品| 欧美精品亚洲二区| 国产精品国产三级国产| 国产一区久久| 亚洲综合欧美日韩| 欧美a级片网| 99国产精品私拍| 美女久久一区| 国产一区二区三区高清在线观看| 日韩午夜三级在线| 麻豆精品视频在线| 久久av一区二区三区| 国产精品呻吟| 亚洲欧美国产高清va在线播| 亚洲国产精品va在线观看黑人| 亚洲天堂免费观看| 欧美日韩伦理在线免费| 亚洲精品国久久99热| 亚洲国产精品成人| 欧美国产成人精品| 亚洲精品一区中文| 最新国产の精品合集bt伙计| 欧美超级免费视 在线| 99精品99久久久久久宅男| 久久久久久久网站| 91久久久亚洲精品| 美女在线一区二区| 亚洲黄色三级| 亚洲精品黄色| 欧美日韩精品是欧美日韩精品| 亚洲美女av网站| 亚洲乱码国产乱码精品精可以看| 久久久久久网| 日韩一级成人av| 一本色道久久综合亚洲精品婷婷| 欧美午夜激情小视频| 久久视频免费观看| 欧美国产视频在线| 欧美一区二区三区免费大片| 亚洲一区制服诱惑| 亚洲一区在线视频| 亚洲福利视频二区| 亚洲一区二区在线免费观看| 国产一区二区中文| 一本色道久久综合狠狠躁篇怎么玩 | 国产精一区二区三区| 欧美成人国产va精品日本一级| 欧美乱人伦中文字幕在线| 午夜精品国产更新| 欧美不卡视频一区| 久久夜色精品一区| 国产精品看片资源| 亚洲国产精品福利| 一区在线影院| 午夜精品亚洲一区二区三区嫩草| 日韩午夜在线视频| 欧美激情一区二区三区高清视频| 久久成人人人人精品欧| 国产精品最新自拍| 性做久久久久久| 午夜伦理片一区| 国产精品久久久久久福利一牛影视| 亚洲精选国产| 亚洲小视频在线观看|