C语言中scanf函数的输入类型

本文介绍了C语言中scanf函数的使用,分析了题目中给出的四个选项,重点讨论了每个选项的合法性。错误选项D的问题在于%6.2f不符合double型变量z的输入格式,应使用lf。其他选项的格式虽然在printf中可能有不同的含义,但在scanf中都是合法的输入格式。
摘要由CSDN通过智能技术生成

一.背景

突然看到一个C语言基础scanf输入题,在深刻理解后把它记录下来。

二.问题描述

若x,y均定义为int型,z定义为double型,以下不合法的scanf函数调用语句是:
A)scanf(" %d%lx,%le",&x,&y,&z);
B)scanf("%2d * %d%lf",&x,&y,&z);
C)scanf("%x %* d%o",&x,&y);
D)scanf("%x%o%6.2f",&x,&y,&z);

三.解题思路

此题扫一眼选项,立刻就看出D中%6.2f错误,f表示的是单精度float型。下来解释下其他选项:

        A.%lx表示long x,以16进制的长整型输入;

%le中,l表示双精度浮点数,e表示指数形式。正确

        B.在printf中%2d是将数字按宽度为2,采用右对齐方式输出,如果数据位数不到2位,则左边补空格,%.2d和% 02d一样,数据位不足2,左边补0。但在scanf中却没什么用,但是合法;

* %d中的*,意思就是在输入数据的时候也要输上,就相当于分隔符;

%lf对应double型。

        C.%x表示16进制输入;

%*d表示忽略该数的输入,就是无论你输入什么指值,都不会被读到;

%o表示八进制输入。

        D.在printf中%6.2f表示按宽度为6,小数点后保留两位的单精度(float)格式输出。在scanf中%6.2没什么用,但问题出在f,与题中z的双精度(double)类型不符,应该是lf。

四.补充

B选项中%2d对齐方式也可作以下操作%-d,右对齐,%+d,左对齐。默认左对齐。

C选项中%*d在scanf中是没什么用,但在printf("%*d",5,3)中,*就是5,指数据宽度输出的3占5个格子。


 

  • 8
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值