PTA1060 Are They Equal

A1060 Are They Equal

 学到了如何利用string容器求一个数的科学计数法~

#include<iostream>
#include<string>
using namespace std;

int n;

//按所需精度,转换为科学记数法的形式
//数的形式有两种,诸如:0.aaa 和 bbb.aaa,只须在除前导零后判断第一位是否是'.'
string deal(string s,int& e)
{
    int k = 0;
    //1.除前导零
    //这里存在一个特殊情况,当数为00000.0000时
    //虽然大小是0,但也要经过一系列处理,去前导零和小数点后的0
    //所以经过处理后,变为0,用长度来判断是否是0
    //所以这里需要s.length() > 0,因为可能数就是0,再erase()会出错
    while(s.length() > 0 && s[0] == '0')
        s.erase(s.begin());
    //2.1处理诸如000.aaa的数
    if(s[0] == '.')
    {
        s.erase(s.begin()); //去小数点
        while(s.length() > 0 && s[0] == '0') //计算指数,小数点后有几个零,e对应减去
        {
            s.erase(s.begin());
            e --;
        }
    }
    //2.2处理诸如bbb.aaa的数
    else{
        while(k < s.length() && s[k] != '.') //计算指数,找到小数点的位置
        {
            k ++;
            e ++;
        }
        if(k < s.length()) s.erase(s.begin() + k);  //如果有小数点,删去
    }
    if(s.length() == 0) e = 0;  //刚刚说的特殊情况
    int num = 0;
    k = 0;
    string res;
    while(num < n)  //按精度求
    {
        if(k < s.length()) res += s[k ++];
        else res += '0';  //不足补零
        num ++;
    }
    return res;  //返回
}

int main()
{
    string a,b;
    cin >> n >> a >> b;
    int e1 = 0,e2 = 0;
    string aa = deal(a,e1);
    string bb = deal(b,e2);
    if(aa == bb && e1 == e2)
    {
        cout << "YES" << ' ' << "0." << aa << "*10^" << e1 << endl;
    }
    else
    {
        cout << "NO" << ' ' << "0." << aa << "*10^" << e1 << ' ' << "0." << bb << "*10^" << e2 << endl;
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值