PAT_1060. Are They Equal

//
//  main.cpp
//  PAT_1060. Are They Equal
//
//  Created by wjq on 17/5/16.
//  Copyright © 2017年 wjq. All rights reserved.
//  
#include <iostream>
#include <string>
using namespace std;
int N;
string a,b;
int getresult(string &s)
{
    int i=0,exp;
    //找出小数点位置,记录编号
    while(s[i]!='.'&&i<s.length())
        i++;
    exp=i;
    if(i!=s.length())
        s.erase(s.begin()+i);
    
    //去掉前导0
    i=0;
    while(s[i]=='0'&&i<s.length())
        i++;
    if(i==s.length())
    {
        s="";
        exp=0;
    }
    else
    {
        exp-=i;
        s=s.substr(i,s.length()-i);
    }
    //后面补0
    while(s.length()<N)
        s+="0";
    
    //截掉多出的部分
    s=s.substr(0,N);
    
    //补上0.
    s="0."+s;
    return exp;
}
int main()
{
    cin>>N>>a>>b;
    int exp1=getresult(a);
    int exp2=getresult(b);
    if(exp1==exp2&&a==b)
        cout<<"YES "<<a<<"*10^"<<exp1<<endl;
    else
        cout<<"NO "<<a<<"*10^"<<exp1<<" "<<b<<"*10^"<<exp2<<endl;
}


这题特别麻烦,一个好的思路可以解决很多麻烦的事情,比如我一开始想分类处理整数和浮点数,沿着这个思路下去代码量太大,放弃了.

然而,这道题的关键在于

找出小数点的位置和第一个有效位(去掉所有前导0)对最后的次数的影响.(10^x,次数就是指这个x)

我举几个例子来说明.

00.000123  小数点在数组中的位置为i=2,第一个有效位的位置为i=6, 2-6+1=-3 次.

0123.45670  小数点在数组中的位置为i=4,第一个有效位的位置为i=2,  4-2+1=3 次

1234 虽然没有小数点,但我们可以认为小数点在结尾,也就是在数组中的位置为i=4,第一个有效位的位置为i=1, 4-1+1=4次


规律: 次数=小数点的下标-第一个有效位的下标+1


一旦发现了这个规律,思路就会产生了.

我们不需要对整数和浮点数分类处理.只要把字符串小数点去掉就可以了.

去掉小数点之后,就可以完全看作是整数了.

剩下的问题 就是解决形如   0001231120 这样的串,我们怎么按照题目的要求输出呢?

1.去掉前导0

2.对字符串补0直到字符串达到N位.

3.对字符串进行裁剪,最多留下N位.

4.在字符串前面加上"0.

应该很容易理解,步骤2有时候不一定会执行,因为有时候我们得到的串已经大于N位

比如这样的输入 3 32134213 34121341 ,去掉小数点和前导0后剩下的字符串长度还是大于3,这时候再做第三步裁剪,也是能够符合题意要求.

总而言之,就是一个先补位再裁剪的想法,一定是满足题意的.


下面补充一下自己的C++ string 函数库......每次用的时候都要百度...心累.....

1.erase函数的总结.

erase函数的原型如下:
(1)string& erase ( size_t pos = 0, size_t n = npos );
(2)iterator erase ( iterator position );
(3)iterator erase ( iterator first, iterator last );
也就是说有三种用法:
(1)erase(pos,n); 删除从pos开始的n个字符,比如erase(0,1)就是删除第一个字符
(2)erase(position);删除position处的一个字符(position是个string类型的迭代器)
(3)erase(first,last);删除从first到last之间的字符(first和last都是迭代器)
下面给一个例子:

#include <iostream>
#include <string>
using namespace std;
int main ()
{
    string str ("This is an example phrase.");
    string::iterator it;
    
    // 第(1)种用法
    str.erase (10,8);
    cout << str << endl;        // "This is an phrase."
    
    // 第(2)种用法
    it=str.begin()+9;
    str.erase (it);
    cout << str << endl;        // "This is a phrase."
    
    // 第(3)种用法
    str.erase (str.begin()+5, str.end()-7);
    cout << str << endl;        // "This phrase."
    return 0;
}


 

2.如何得到string字符串中的一部分子串?

s.substr(起始下标,子串长度)   ,获得的子串会包含起始下标

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值