1060 Are They Equal 之巧用string解决科学计数法

题目

If a machine can save only 3 significant digits, the float numbers 12300 and 12358.9 are considered equal since they are both saved as 0.123×10^5 with simple chopping. Now given the number of significant digits on a machine and two float numbers, you are supposed to tell if they are treated equal in that machine.

在这里插入图片描述

分析

题意是让我们根据给出的整数n(确定取的位数)和两个数,来判断他们是否相等。如3 12300 12358.9 则输出YES 因为他们取3位有效数字就是0.12310^5;而3 120 128,则输出 NO ,因为他们一个为0.12010^3 ,另一个为0.128*10^3。
这道题如果用数组来解决的话可能会涉及到比较多数组下标的问题,而如果用STL里的string就会感受到string的奇怪魅力啦。

解题

我一开始做这道题的时候没有想那么多,以为就跟给出的例子一样都是大于1的数,没想到有0.000几的情况,所以就GG了。因此这道题的正确解法是:
分两种情况:

  1. 0.a1a2a3…(大于1)
  2. b1b2b3.a1a2a3…(小于1)

另外可能会有0在前面搞事情(如00123实际就是123),搞清楚这几点就没问题了,上代码:

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

int n;
string deal(string s, int &e)
{
	int k = 0;
	while(s.length() > 0 && s[0] == '0')
	{
		s.erase(s.begin());
	}
	if(s[0] == '.')
	{
		s.erase(s.begin());
		while(s.length() > 0 && s[0] == '0')
		{
			s.erase(s.begin());
			e--;
		}
	}
	else
	{
		while(k < s.length() && s[k] != '.')
		{
			k++;
			e++;
		}
		if(k < s.length())
		{
			s.erase(s.begin() + k);
		}
	}
	if(s.length() == 0) //删掉这一步会过不了最后一个测试点,000.,全是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 s1, s2, s3, s4;
	cin >> n >> s1 >> s2;
	int e1 = 0, e2 = 0;
	s3 = deal(s1, e1);
	s4 = deal(s2, e2);
	if(s3 == s4 && e1 == e2) cout << "YES 0." << s3 << "*10^" << e1 << endl;
	else cout << "NO 0." << s3 << "*10^" << e1 << " 0." << s4 << "*10^" << e2 << endl;
	return 0;
}

小结

  1. 复习了string的用法,str.erase(), str += “xx”, str[数组]使用, str.length(), str.begin(), str.end()等等。
  2. 科学计数法就是分成两步,一为尾数,一为指数,分清楚就没问题了。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值