zoukankan      html  css  js  c++  java
  • [C语言教程]四、(1)C语言中的基本输入输出

    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
    ➤微信公众号:山青咏芝(shanqingyongzhi)
    ➤博客园地址:山青咏芝(www.zengqiang.org
    ➤GitHub地址:https://github.com/strengthen/LeetCode
    ➤原文地址:https://www.cnblogs.com/strengthen/p/11417040.html 
    ➤如果链接不是山青咏芝的博客园地址,则可能是爬取作者的文章。
    ➤原文已修改更新!强烈建议点击原文地址阅读!支持作者!支持原创!
    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★

    一、字符输出函数putchar

    putchar函数是字符输出函数,其功能是在终端(显示器)输出单个字符。其一般调用形式为: 
    putchar(字符变量); 例: 

    1 putchar(‘A’); /*输出大写字母A */
    2 putchar(x);  /*输出字符变量x的值*/
    3 putchar(‘
    ’); /*换行*/

    二、字符输入函数getchar

    getchar函数的功能是接收用户从键盘上输入的一个字符。其一般调用形式为: 
    getchar(); 
    getchar会以返回值的形式返回接收到的字符.通常的用法如下: 

    1 char c;  /*定义字符变量c*/
    2 c=getchar(); /*将读取的字符赋值给字符变量c*/

    三、格式化输出函数printf

    printf函数叫做格式输出函数,其功能是按照用户指定的格式,把指定的数据输出到屏幕上.printf函数的格式为: 
    printf(“格式控制字符串”,输出表项); 
    其中格式控制字符串用来说明输出表项中各输出项的输出格式(好比我要吃苹果,告诉printf是做成罐头吃还是直接吃)。输出表项列出了要输出的项,各输出项之间用逗号分开。输出表项也可以没有,则表示输出的是格式字符串本身。 
    格式控制字符串有两种:格式字符串和非格式字符串。非格式字符串在输出的时候原样打印;格式字符串是以%打头的字符串,在”%”后面跟不同格式字符,用来说明输出数据的类型、形式、长度、小数位数等。格式字符串的形式为: % [输出最小宽度] [.精度] [长度] 类型 
    例如,%d格式符表示 用十进制整形格式输出。%f表示用实型格式输出,%5.2f 格式表示输出宽度为5(包括小数点),并包含2位小数。常用的输出格式及含义如下: 

    格式字符  
    d , i 以十进制形式输出有符号整数(正数不输出符号)
    O 以八进制形式输出无符号整数(不输出前缀0)
    x 以十六进制形式输出无符号整数(不输出前缀0x)
    U 以十进制形式输出无符号整数
    f 以小数形式输出单、双精度类型实数
    e 以指数形式输出单、双精度实数
    g 以%f或%e中较短输出宽度的一种格式输出单、双精度实数
    C 输出单个字符
    S 输出字符串


    关于printf的更多用法,请您自行上机实验。 例: 

     1 #include<stdio.h>
     2 int main()
     3 {
     4     int a=12;
     5     float b=3.1415;
     6     char c='A';
     7     printf("%d
    ",a);
     8     printf("o%o
    ",a);
     9     printf("0x%x
    ",a);
    10     printf("%3.2f
    ",b);
    11     printf("%c
    ",c);
    12     getchar();
    13     return 0;
    14 }

    *修饰符在printf()中的用法:  

    假如您不想事先指定字段宽度,而是希望由程序来制定该值,那么您可以在字段宽度部分使用*代替数字来达到目的,但是您也必须使用一个参数来告诉函数宽度的值是多少。具体的说,如果转换说明符为%*d,那么参数列表中应该包括一个*的值和一个d的值,来控制宽度和变量的值。该技术也可以和浮点值一起使用来指定精度和字段宽度。 
    您可以参考下面的例子: 

     1 /*使用可变宽度输出字段*/
     2 #include<stdio.h>
     3 int main(void)
     4 {
     5     unsigned width,precision;
     6     int number = 256;
     7     double weight = 25.5;
     8     printf("Please input number's 
    ");
     9     scanf("%d",&width);
    10     printf("The number is: %*d
    ",width,number);
    11     printf("Then please input width and precision:
    ");
    12     scanf("%d %d",&width,&precision);
    13     printf("Weight = %*.*f
    ",width,precision,weight);
    14     return 0;
    15 }

    gcc下运行过程及结果如下:

    1 Please input number's 
    2 6
    3 The number is:    256
    4 Then please input width and precision:
    5 8 3
    6 Weight =   25.500

    关于printf()的返回值

    printf函数的返回值是返回所打印的字符的数目。如有输出错误,那么printf()会返回一个负数(printf()的一些老版本会有不同的值)。

    四、格式化输入函数scanf

    scanf函数称为格式输入函数,即按照格式字符串的格式,从键盘上把数据输入到指定的变量之中。Scanf函数的调用的一般形式为: 
    scanf(“格式控制字符串”,输入项地址列表); 
    其中,格式控制字符串的作用与printf函数相同,但不能显示非格式字符串,也就是不能显示提示字符串。地址表项中的地址给出各变量的地址,地址是由地址运算符”&”后跟变量名组成的。 
    Scanf 函数中格式字符串的构成与printf函数基本相同,但使用时有几点不同. 
    (1) 格式说明符中,可以指定数据的宽度,但不能指定数据的精度。例: 

    1 float a;
    2 scanf(“%10f”,&a);  //正确
    3 scanf(“%10.2f”,&a); //错误

    (2) 输入long类型数据时必须使用%ld,输入double数据必须使用%lf或%le。     

    (3) 附加格式说明符”*”使对应的输入数据不赋给相应的变量。 
    scanf()函数所用的转换说明符与printf()所用的几乎完全相同。主要区别在于printf()把%f、%e、%E、%g、%G同时用于float类型和double类型,而scanf()只是把他们用于float类型,而用于double类型时要求使用l(字母l)修饰符。

    转换说明符  
    %c 把输入解释成一个字符
    %d 把输入解释成一个有符号十进制整数
    %e,%f,%g,%a 把输入解释成一个浮点数(%a是C99的标准)
    %E,%F,%G,%A 把输入解释成一个浮点数(%A是C99的标准)
    %i 把输入解释成一个有符号十进制整数
    %o 把输入解释成一个有符号的八进制整数
    %p 把输入解释成一个指针(一个地址)
    %s 把输入解释成一个字符串:输入的内容以第一个非空白字符作为开始,并且包含直到下一个空白字符的全部字符
    %u 把输入解释成一个无符号十进制整数
    %x,%X 把输入解释称一个有符号十六进制整数

    *修饰符在scanf中()的用法:

    *在scanf()中提供截然不同的服务,当把它放在%和说明符字母之间时,它使函数跳过相应的输入项目。请参考程序事例:

     1 /*用*跳过scanf接收的数字*/
     2 #include<stdio.h>
     3 int main(void)
     4 {
     5         int num;
     6         printf("Please enter three number:
    ");
     7         scanf("%*d %*d %d",&num);
     8         printf("The last number is %d
    ",num);
     9         return 0;
    10 }

    gcc下运行结果如下:    

    1 Please enter three number:
    2 2014 2015 2016
    3 The last number is 2016

    关于scanf()的返回值

    scanf() 函数返回成功读入的项目的个数。如果它没有读取任何项目(比如它期望接收一个数字而您却输入的一个非数字字符时就会发生这种情况),scanf()返回0。 
    当它检测到“文件末尾”(end of file)时,它返回EOF(EOF在是文件stdio.h中的定义好的一个特殊值,一般,#define指令将EOF的值定义为-1)。当您学过循环之后,或在参加ACM这样的比赛及使用在线评测系统的时候会经常用到这种写法。

  • 相关阅读:
    最长公共子序列
    字符串循环左移
    收集雨水问题
    直方图最大矩阵面积
    逆波兰表达式
    最长括号匹配问题
    机器学习中用来防止过拟合的方法有哪些?
    制作coco数据集以在Detectron框架上进行数据的训练
    关于训练集,验证集,测试集的划分
    配置CUDA和cuDNN以及Detectron过程
  • 原文地址:https://www.cnblogs.com/strengthen/p/11417040.html
Copyright © 2011-2022 走看看