假期刷题打卡--Day5

一、c++刷题

1、MT1021%f格式符

输入一个实数,第一次按实型输出;第二次保留2位小数输出;第三次保留3位小数但最小列宽8列输出,空格分隔。

格式

输入格式:

输入实型

输出格式:

输出实型,空格分隔。

样例 1

输入:

31331.14345435

输出:

31331.143454 31331.14 31331.143
分析过程

题目有三个要求,第一次按实型输出;第二次保留2位小数输出和空格分隔这几个要求是我们常见的,使用C语言可以很快的写出来,但是对于第三个要求:第三次保留3位小数但最小列宽8列输出,我原先没有见过这种表述,通过查找资料,得到了如下内容。

  • %f:整数部分全部输出,并输出6位小数;
  • %.nf:整数部分全部输出,并输出n位小数;
  • %m.nf:输出共占m列,n位小数,若数值宽度小于m则左端补空格。

依照上述资料,成功实现了题目要求。

实现代码 
#include 

using namespace std;

int main( )
{
    double a;
    cin >> a ;
    printf("%f ",a);
    printf("%.2f ",a);
    printf("%8.3f",a);

    return 0;
}

2、MT1022小数、指数

输出3.1415926、12345678.123456789的小数、指数形式。

格式

输入格式:

输出格式:

输出为实型,空格分隔

样例 1

输入:

输出:

3.141593 3.141593e+000  
12345678.123457 1.234568e+007

看不懂,思密达~,所以,我就去求助小码哥了,嘿嘿。

下面是对小码哥的讲解的理解:

指数形式输出的方式:

1.printf与%e搭配使用;

2.cout<

注意:虽然输出为指数型,但是e后面只有两位数。

而题目要求的是e后面有三位,所以还需要采用其他方法解决。 

在科学计数法中,为了使公式简便,可以用带“E”的格式表示。当用该格式表示时,E前面的数字和“E+”后面要精确到十分位,(位数不够末尾补0),例如7.8乘10的7次方,正常写法为:7.8x10^7,简写为“7.8E+07”的形式

小数点左移几位,就乘以10的相应次方;右移几位,就是乘以10的负几次方。

分析过程

输出3.1415926、12345678.123456789的小数、指数形式。

输出:

3.141593 3.141593e+000  
12345678.123457 1.234568e+007

        对于第一个输出(输出的第一列)不难看出,就是保留小数点后六位,所以按照平时常用的.6f%就可,但是对于后面的一个输出,发现它是e后面有三个数,而默认的科学计数法是两位数,所以这就需要我们自己把后面这三位数表示出来。

        首先不能使用默认的方式,所以e+肯定需要自己输出,除此之外,我们需要自己按照科学计数法的方式来计算e前的数和e后的数。

        通过分析可以发现e前小数点后也有六位数字,所以就需要我们首先将所给数化成科学计数法的那种形式(整数部分大于0小于10),然后直接按照.6f%输出,而e后的数字就是转成科学计数法表示时小数点移动的次数,所以在转换成科学计数法的时候需要设置一个计数的变量来表示e后的数字。

        但是,问题还没有解决,再此题中要求e后有三位数字,而指数在最后一位表示,所以,前面的位置需要使用0进行填充,此时就需要用到setfill('0') 来设置输出流中的填充字符,并使用 setw(3) 来设置输出宽度。这样就可以满足题意了。

在C++中,setw(int n)用来控制输出间隔,可以设置相应的宽度,要想实现其他字符填充,可以与setfill()配合使用。

例:在本题中,e后的数字个数为3,那么设置宽度为3,即setw(3),前面用'0'填充,即setfill('0')。

所以语句为:

cout << setw(3) << setfill('0') << i;
实现代码
#include 

using namespace std;
double a = 3.1415926 ,b = 12345678.123456789;

void solve(double a){
    printf("%f ",a);

    int i = 0;
    while(a>10){
        a/=10.0;
        i++;
    }

    printf("%.6fe+",a);
    cout << setw(3) << setfill('0') << i;
}
int main( )
{
    solve(a);
    cout << endl;
    solve(b);
    return 0;
    
    cout << a << endl ;
    printf("%f ",b);  
    cout << b ;
    
    return 0;
}

明天继续吧。

你可能感兴趣的:(假期打卡学习,算法,c++,c语言)