zoukankan      html  css  js  c++  java
  • C++中cin,cout进制,数据宽度与对齐,精度,取整

    原文转载地址:https://blog.csdn.net/tt_twilight/article/details/70215588

    1、数的进制

    [转载]未完的c++输入输出 默认进制:
    默认状态下,数据按十进制输入输出。如果要求按八进制或十六进制输入输出,在cin或cout中必须指明相应的数据形式,oct为八进制,hex为十六进制,dec为十进制。
    [转载]未完的c++输入输出 举例:
    int i, j, k, l;
    cout<<”Input i(oct), j(hex), k(hex), l(dec):”<<endl;
    cin>>oct>>i; //输入为八进制数
    cin>>hex>>j; //输入为十六进制数
    cin>>k; //输入仍为十六进制数
    cin>>dec>>l; //输入为十进制数
    cout<<”hex:”<<”i=”<<hex<<i<<endl;
    cout<<”dec:”<<”j=”<<dec<<j<<′t′<<”k=”<<k<<endl;
    cout<<”oct:”<<”l=”<<oct<<l;
    cout<<dec<<endl; //恢复十进制输出状态
    【执行结果】:
    (1)输出提示:Input i(oct), j(hex), k(hex), l(dec):
    (2)此时从键盘输入: 032 0x3f 0xa0 17 <CR>
    (3)输出结果为:
    hex:i=1a
    dec:j=63 k=160
    oct:l=21
    [转载]未完的c++输入输出 几点说明:
    [转载]未完的c++输入输出 使用不带.h的头文件<iostream>时,必须在cin中指明数制,否则从键盘输入时,不认八进制和十六进制数开头的0和0x标志。指明后可省略0和0x标志。
    [转载]未完的c++输入输出 进制控制只适用于整型变量,不适用于实型和字符型变量。
    [转载]未完的c++输入输出 输入数据的格式、个数和类型必须与cin中的变量一一对应,否则不仅使输入数据错误,而且影响后面其他数据的正确输入。

    [转载]未完的c++输入输出 在cin或cout中指明数制后,该数制将一直有效,直到重新指明使用其他数制。

     2、数据间隔与对齐
    [转载]未完的c++输入输出 常用设置方法:输出空格符或回车换行符。
    [转载]未完的c++输入输出 指定数据输出宽度:用C++提供的函数setw()指定输出数据项的宽度。setw()括号中通常给出一个正整数值,用于限定紧跟其后的一个数据项的输出宽度。如:setw(8)表示紧跟其后的数据项的输出占8个字符宽度。
    [转载]未完的c++输入输出 举例:
    int i=2, j=3;
    float x=2.6, y=1.8;
    cout<<setw(6)<<i<<setw(10)<<j<<endl;
    cout<<setw(10)<<i*j<<endl;
    cout<<setw(8)<<x<<setw(8)<<y<<endl;
    cout<<setiosflags(ios::left)<<setw(10)<<i*j<<endl; //左对齐
    则输出结果为:
         2         3
             6
         2.6     1.8
    [转载]未完的c++输入输出 说明:
    [转载]未完的c++输入输出 如果数据的实际宽度小于指定宽度,按右对齐的方式在左边留空,如果数据的实际宽度大于指定宽度,则按实际宽度输出,即指定宽度失效。
    [转载]未完的c++输入输出 setw()只能限定紧随其后的一个数据项,输出后即回到默认输出方式。
    [转载]未完的c++输入输出 使用setw()必须在程序开头再增加一句: #include<iomanip>
    //setiosflags(ios::right)  右对齐 默认
    //setiosflags(ios::left)   左对齐

    3、数的精度控制
       #include   <iostream>  
      #include   <iomanip>  
      using   namespace   std;  
       
      int   main(void)  
      {      
      double   pi   =   3.1415926535897932384;  
      double   b   =   3.1415926535897932384;  
      cout<<setprecision(5)<<b<<endl        //5位有效数字
       <<fixed<<setprecision(5)<<pi<<endl;  //小数点后5位
      }
    //保留精度时按四舍五入原则

    4、浮点数的取整

           C/C++取整函数ceil(),floor()
           double floor(double x);
           double ceil(double x);


           使用floor函数。floor(x)返回的是小于或等于x的最大整数。
           如:     floor(10.5) == 10    floor(-10.5) == -11


           使用ceil函数。ceil(x)返回的是大于x的最小整数。
           如:     ceil(10.5) == 11    ceil(-10.5) ==-10
       
           floor()是向负无穷大舍入,floor(-10.5) == -11;

           ceil()是向正无穷大舍入,ceil(-10.5) == -10

  • 相关阅读:
    Javascript高级编程学习笔记(32)—— 客户端检测(1)能力检测
    Javascript高级编程学习笔记(31)—— BOM(5)screen、history对象
    Javascript高级编程学习笔记(30)—— BOM(4)navigator对象
    Javascript高级编程学习笔记(29)—— BOM(3)location对象
    Javascript高级编程学习笔记(28)—— BOM(2)window对象2
    Javascript高级编程学习笔记(27)—— BOM(1)window对象1
    逆向与反汇编工具
    Silicon Labs
    sk_buff 里的len, data_len, skb_headlen
    IP分片重组的分析和常见碎片攻击 v0.2
  • 原文地址:https://www.cnblogs.com/jack1208-rose0203/p/14328498.html
Copyright © 2011-2022 走看看