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(起始下标,子串长度) ,获得的子串会包含起始下标
- PAT_1060: Are They Equal
- PAT_1060. Are They Equal
- 1060. Are They Equal
- 【PAT1060】Are They Equal
- 1060. Are They Equal
- 1060.Are They Equal
- 1060. Are They Equal
- Are They Equal (25)
- 1060. Are They Equal
- 1060. Are They Equal
- 1060. Are They Equal
- Are They Equal (25)
- A1060.Are They Equal
- PAT 1060 Are They Equal
- 1060. Are They Equal (25)
- 1060. Are They Equal (25)
- 1060. Are They Equal (25)
- PAT 1060. Are They Equal
- 更改Anaconda下载源
- 字串的连接最长路径查找
- Dockerfile 常用指令
- android开发之Gson的使用
- POI对Excel单元格的格式的设置参数
- PAT_1060. Are They Equal
- C语言程序设计(17)
- TCP协议回顾
- 人脸特征点检测(一)
- CSS画图形
- 分布式缓存技术redis学习系列(五)——redis实战(redis与spring整合,分布式锁实现)
- WebAPI+NLog实现接口调用日志输出
- intellij idea 最常用的快捷键
- hql与sql的区别