码迷,mamicode.com
首页 > 其他好文 > 详细

51Nod 1873 初中的算术

时间:2018-04-07 11:25:37      阅读:322      评论:0      收藏:0      [点我收藏+]

标签:ret   sizeof   style   字符   ring   pow   return   pre   ems   

大神的字符串快速幂

 1 #include <iostream>
 2 #include <string>
 3 #include <algorithm>
 4 #include <cstdio>
 5 #include <cstring>
 6 using namespace std;
 7 
 8 //字符串的乘法
 9 string multi(string a, string b){
10     int i, j, arr[200], len = a.length() + b.length();
11     memset(arr, 0, sizeof arr);
12     reverse(a.begin(), a.end());
13     reverse(b.begin(), b.end());
14     for (int i = 0; i<a.length(); i++)
15     for (int j = 0; j<b.length(); j++)
16         arr[i + j] += (a[i] - 0)*(b[j] - 0);
17     for (int i = 0; i<len; i++){
18         arr[i + 1] += arr[i] / 10;
19         arr[i] %= 10;
20     }
21     string ret = string(len, 0);
22     for (int i = 0; i<len; i++)
23         ret[i] += arr[i];
24     reverse(ret.begin(), ret.end());//翻转
25     return ret;
26 }
27 string Str_Pow(string x, int p){
28     string ret = "1";
29     while (p){
30         if (p & 1) ret = multi(ret, x);
31         x = multi(x, x);
32         p >>= 1;
33     }
34     return ret;
35 }
36 int main(){
37     string a;
38     int n;
39     while (cin >> a >> n){
40         int index = a.find(.);
41         if (index == -1) index = 0;
42         else {
43             //substr() 是字符串截取函数
44             a = a.substr(0, index) + a.substr(index + 1);
45             index = (a.length() - index)*n;
46         }
47         a = Str_Pow(a, n);
48         a = a.substr(0, a.length() - index) + "." + a.substr(a.length() - index);
49         int i;
50         for (i = 0; i<a.length(); i++)
51             if (a[i] != 0)
52                 break;
53         //substr(i) 从i到end
54         a = a.substr(i);
55         for (int i = a.length() - 1; i >= 0; i--){
56             if (a[i] == .){
57                 a = a.substr(0, i); 
58                 break;
59             }
60             else if (a[i] != 0){
61                 a = a.substr(0, i + 1);
62                 break;
63             }
64         }
65         cout << a << endl;
66     }
67     return 0;
68 }

 

51Nod 1873 初中的算术

标签:ret   sizeof   style   字符   ring   pow   return   pre   ems   

原文地址:https://www.cnblogs.com/jaydenouyang/p/8732466.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!