zoukankan      html  css  js  c++  java
  • #ACsaber ——简单排序、字符串加空格、数组中的行 ~20.10.22

    第一题:简单排序

    点这里看原题

    过程:由于第一次打这个有点紧张,明明这么简单却手抖没写出来……

    答案

    #include<bits/stdc++.h>
    using namespace std;
    int a[3], b[3];
    int main(){
        for(int i = 0; i < 3; i ++)
            cin >> a[i];
        for(int i = 0; i < 3; i ++) b[i] = a[i];
        sort(a + 0, a + 3);
        for(int i = 0; i < 3; i ++)
            cout << a[i] << endl;
        cout << endl;
        for(int i = 0; i < 3; i ++)
            cout << b[i] << endl;
        
        return 0;
    }
    

    第二题 :字符串加空格

    过程:由于字符串的输入输出不熟练,还是被秒杀了……

    答案

    #include<iostream>
    using namespace std;
    int main()
    {
        string a;
        getline(cin, a);
        for(char c : a) cout << c << ' '; 
        return 0;
    }
    

    第三题:数组中的行

    点这里

    过程:这个鬼题卡了我一个小时,原因就是float 和double!

    float会在取近似值的时候舍掉对应精度后面的所有数值!只有double 才会四舍五入!
    首先看看这个程序:

    #include<bits/stdc++.h>
    using namespace std;
    int main(){
        float a = 1.00;
        for(int i = 1; i <= 10; i ++)
            a += 0.01, printf("当a等于 %f 时,精确到小数点后两位数是 %.1f 
    ", a , a);
        puts("");
        for(int i = 1; i <= 10; i ++)
            a += 0.001, printf("当a等于 %f 时,精确到小数点后两位数是 %.2f 
    ", a , a);
        
        return 0;
    }
    

    运行结果:

    当a等于 1.010000 时,精确到小数点后两位数是 1.0 
    当a等于 1.020000 时,精确到小数点后两位数是 1.0 
    当a等于 1.030000 时,精确到小数点后两位数是 1.0 
    当a等于 1.040000 时,精确到小数点后两位数是 1.0 
    当a等于 1.050000 时,精确到小数点后两位数是 1.0 
    当a等于 1.060000 时,精确到小数点后两位数是 1.1 
    当a等于 1.070000 时,精确到小数点后两位数是 1.1 
    当a等于 1.080000 时,精确到小数点后两位数是 1.1 
    当a等于 1.090000 时,精确到小数点后两位数是 1.1 
    当a等于 1.100000 时,精确到小数点后两位数是 1.1 
    
    当a等于 1.101000 时,精确到小数点后两位数是 1.10 
    当a等于 1.102000 时,精确到小数点后两位数是 1.10 
    当a等于 1.103000 时,精确到小数点后两位数是 1.10 
    当a等于 1.104000 时,精确到小数点后两位数是 1.10 
    当a等于 1.105000 时,精确到小数点后两位数是 1.11 
    当a等于 1.106000 时,精确到小数点后两位数是 1.11 
    当a等于 1.107000 时,精确到小数点后两位数是 1.11 
    当a等于 1.108000 时,精确到小数点后两位数是 1.11 
    当a等于 1.109000 时,精确到小数点后两位数是 1.11 
    当a等于 1.110000 时,精确到小数点后两位数是 1.11 
    

    于是我们可以发现,当精度到小数点一位时,float 居然是五舍六入!!!

    再看看double的表现:

    #include<bits/stdc++.h>
    using namespace std;
    int main(){
        double a = 1.00;
        for(int i = 1; i <= 10; i ++)
            a += 0.01, printf("当a等于 %f 时,精确到小数点后两位数是 %.1lf 
    ", a , a);
        puts("");
        for(int i = 1; i <= 10; i ++)
            a += 0.001, printf("当a等于 %f 时,精确到小数点后两位数是 %.2lf 
    ", a , a);
        
        return 0;
    }
    

    运行结果:

    当a等于 1.010000 时,精确到小数点后两位数是 1.0 
    当a等于 1.020000 时,精确到小数点后两位数是 1.0 
    当a等于 1.030000 时,精确到小数点后两位数是 1.0 
    当a等于 1.040000 时,精确到小数点后两位数是 1.0 
    当a等于 1.050000 时,精确到小数点后两位数是 1.1 
    当a等于 1.060000 时,精确到小数点后两位数是 1.1 
    当a等于 1.070000 时,精确到小数点后两位数是 1.1 
    当a等于 1.080000 时,精确到小数点后两位数是 1.1 
    当a等于 1.090000 时,精确到小数点后两位数是 1.1 
    当a等于 1.100000 时,精确到小数点后两位数是 1.1 
    
    当a等于 1.101000 时,精确到小数点后两位数是 1.10 
    当a等于 1.102000 时,精确到小数点后两位数是 1.10 
    当a等于 1.103000 时,精确到小数点后两位数是 1.10 
    当a等于 1.104000 时,精确到小数点后两位数是 1.10 
    当a等于 1.105000 时,精确到小数点后两位数是 1.10 
    当a等于 1.106000 时,精确到小数点后两位数是 1.11 
    当a等于 1.107000 时,精确到小数点后两位数是 1.11 
    当a等于 1.108000 时,精确到小数点后两位数是 1.11 
    当a等于 1.109000 时,精确到小数点后两位数是 1.11 
    当a等于 1.110000 时,精确到小数点后两位数是 1.11 
    

    double 就正常了!!!

  • 相关阅读:
    R学习 第二篇:矩阵和数组
    R学习 第一篇:变量和向量
    PowerBI开发 第七篇:数据集和数据刷新
    PowerBI开发 第八篇:查询参数
    PowerBI开发 第六章:数据网管
    专用管理连接(DAC)和单用户模式
    PowerBI开发 第五篇:关系和交互
    PowerBI开发 第四篇:DAX 表达式基础
    PowerBI开发 第三篇:报表设计技巧
    分区表介绍
  • 原文地址:https://www.cnblogs.com/yuanyulin/p/14026733.html
Copyright © 2011-2022 走看看