【问题描述】
编写一个程序,将用小数表示的浮点数,转换成科学计数法的形式输出。输入的数据没有符号,小数点前后必有数字,且全为有效数据,即小数点后的末尾数字不为0;小数点前若只有一位数字,可以为0,否则小数点前的最高位数字不为0。
提示:以字符串形式保存相关数据。
【输入形式】
从控制台输入一小数,最后有回车换行符,所有输入的字符数不会超过100。
【输出形式】
以科学计数法形式输出数据。输出的数据由以下几部分构成:
1.底数部分是一个小数或整数,若为小数,则小数点前后必有数字,而且都为有效数字。即:小数点前只有一位大于0的数字,小数点后的末尾数字不能为0。若为整数,则只有一位数字,不带小数点。
2.必有小写字母“e”。
3.指数部分是一个整数,若大于等于0,则不带正号“+”。若小于0,则需要带负号“-”,且整数的最高位数字不为0。
【输入样例1】
0.000000000000002
【输出样例1】
2e-15
【输入样例2】
8.9845623489651700659
【输出样例2】
8.9845623489651700659e0
【输入样例3】
367298599999093453490394859509568659795603.4
【输出样例3】
3.672985999990934534903948595095686597956034e41
【样例说明】
以小数形式输入数据,然后转换成科学计数法形式输出。
#include<bits/stdc++.h>
using namespace std;
int main(){
string str;
cin>>str;
//判断第一个字符是否为0(此浮点数是否大于1)
if(str[0]!='0'){
int flag;//记录小数点的位置
flag=str.find('.');//find函数进行寻找
cout<<str[0]<<".";
//再打印小数点移动前后中间的
for(int i=1;i<flag;++i){
cout<<str[i];
}
//剩余的
for(int i=flag+1;i<str.length();++i){
cout<<str[i];
}
cout<<"e"<<flag-1;
}
//第一个数为0
else{
//寻找第一个非0数的位置
int Flag=0;
for(int i=0;i<str.length();++i){
if(str[i]!='0'&&str[i]!='.'){
Flag=i;
break;
}
}
//有只有一位有效数字的特殊情况,如0.003所以判断
if(Flag+1==str.length())
cout<<str[Flag];//打印第一个数
else{
cout<<str[Flag]<<".";//打印第一个数
}
//打印后面的
for(int i=Flag+1;i<str.length();++i){
cout<<str[i];
} cout<<"e-"<<Flag-1;//小于1 e为负数加个负号
}
}