题目——PAT1060 Are They Equal(有关string的操作)

题目链接

 

#include <iostream>
#include <cstdio>
#include <string>
using namespace std;
// 返回str对应的科学计数法形式0.x1x2x3... * 10^k中,x1x2x3...部分
string getBodyLevel(string str,int &level) {
    int len = str.size();
    int posDot = str.find(".");
    int posFirstNum=0;   // 寻找第一个非0数字所在下标
    while(posFirstNum<len &&(str[posFirstNum]=='0' || str[posFirstNum]=='.'))
        posFirstNum++;
    if(posFirstNum==len) {
        level=0;
        return "0";
    }
    if(posDot==string::npos) {
        level=len-posFirstNum;
        return str.substr(posFirstNum);
    } else {
        if(posFirstNum<posDot) {
            level = posDot - posFirstNum;  // 此时level>0
            return str.substr(posFirstNum,level) + str.substr(posDot+1);
        } else {
            level = posDot - posFirstNum + 1;  // 此时level<=0
            return str.substr(posFirstNum);
        }
    }
}
// 进行截取操作
string chop(string str,int n) {
    int len = str.size();
    if(len>=n)
        return str.substr(0,n);
    for(int i=0; i<n-len; i++)
        str+="0";
    return str;
}
void Print(string str, int level) {
    if(str=="0") {
        printf(" 0");
        return ;
    }
    printf(" 0.%s*10^%d",str.c_str(),level);
}
int main() {
    int N;
    string A,B;
    while(cin>>N>>A>>B) {
        int levelA,levelB;
        string chopA = chop(getBodyLevel(A, levelA),N);
        string chopB = chop(getBodyLevel(B, levelB),N);
        if(levelA==levelB && chopA==chopB) {
            printf("YES");
            Print(chopA, levelA);
        } else {
            printf("NO");
            Print(chopA, levelA);
            Print(chopB, levelB);
        }
        printf("\n");
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值