风雨无阻


私信TA

用户名:dotcpp0743622

访问量:832

签 名:

等  级
排  名 18681
经  验 737
参赛次数 0
文章发表 11
年  龄 99
在职情况 学生
学  校 郑州大学
专  业 软件工程

  自我简介:

TA的其他文章

解题思路:

注意事项:

参考代码:

#include<bits/stdc++.h>
using namespace std;

int n=1,a[10000];
void mul(int p[] ){
	int t=0;
    for(int i=1;i<n;i++){
        p[i]=p[i]*2+t;
        t=p[i]/10;
        p[i]%=10;
    }
    if(t) {p[n]=t;n++;}
}

int main()
{
    int N,flag;
    string d;
    cin>>N>>d;
    for(int i=d.length()-1;i>=0;i--){
        if(d[i]=='.')
			flag=n;
		else {
            a[n]=d[i]-'0';
            n++;
        }
    }
    //cout<<"flag="<<flag<<endl; 
    while(N--) mul(a);
    if(a[flag-1]>=5){
        int t=1;
        for(int i=flag;i<n&&t;i++){
            a[i]+=t;
            t=a[i]/10;
            a[i]%=10;
            //cout<<"di"<<i<<endl;
        }
        if(t) {
        	a[n]=t;
        	n++;
		}
    }
    for(int i=n-1;i>=flag;i--)
        cout<<a[i];
    
    return 0;
}


 

0.0分

0 人评分

  评论区

  • «
  • »