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 就正常了!!!

  • 相关阅读:
    Linux 常用命令
    一些实用但不为人知的Unix命令
    Linux 驱动开发笔记(一)
    etcd数据备份和恢复--转发
    使用kubeadm 新加入节点(原始token过期后)---转发
    centos7 ipython安装
    Linux系统 jboss/Tomcat服务器pdf文件乱码问题
    k8s pod节点调度及k8s资源优化
    docker 常见问题处理汇总
    Grafana+Prometheus实现Ceph监控和钉钉告警-转载(云栖社区)
  • 原文地址:https://www.cnblogs.com/yuanyulin/p/14026733.html
Copyright © 2011-2022 走看看