PAT_1060. Are They Equal

来源:互联网 发布:dnf辅助无限提卡端口 编辑:程序博客网 时间:2024/05/17 22:36
////  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(起始下标,子串长度)   ,获得的子串会包含起始下标

原创粉丝点击