c语言-输入输出详解

文章目录

    • 格式化输入输出
      • 占位符
      • printf
      • scanf
    • 字符串输入输出
      • puts()
      • gets()
    • 字符输入输出
      • putchar()
      • getchar()
    • 区别


格式化输入输出

输入输出的库函数的头文件: #include<stdio.h>
输入输出简略过程:
在这里插入图片描述

在介绍格式化输入输出之前我们先来了解一下占位符吧

占位符

1.解析:所谓 “占位符”,就是这个位置可以⽤其他变量的值代⼊。
如:

int a = 10;
printf("a=%d", a);

在这里插入图片描述
2.占位符列举

%a :⼗六进制浮点数,字⺟输出为⼩写。
• %A :⼗六进制浮点数,字⺟输出为⼤写。
• %c :字符。 • %d :⼗进制整数。 •
%e :使⽤科学计数法的浮点数,指数部分的 e 为⼩写。 • %E :使⽤科学计数法的浮点数,指数部分的 E 为⼤写。
%i :整数,基本等同于 %d 。
• %f :⼩数(包含float 类型和 double 类型)。
• %g :6个有效数字的浮点数。整数部分⼀旦超过6位,就会⾃动转为科学计数法,指数部分的 e为⼩写。
• %G :等同于 %g ,唯⼀的区别是指数部分的 E 为⼤写。
• %hd :⼗进制 short int 类型。
• %ho :⼋进制 short int 类型。
• %hx :⼗六进制 short int 类型。
• %hu :unsigned short int类型。
• %ld :⼗进制 long int 类型。
• %lo :⼋进制 long int 类型。
• %lx :⼗六进制 longint 类型。
• %lu :unsigned long int 类型。
• %lld :⼗进制 long long int 类型。
•%llo :⼋进制 long long int 类型。
• %llx :⼗六进制 long long int 类型。
• %llu:unsigned long long int 类型。
• %Le :科学计数法表⽰的 long double 类型浮点数。
• %Lf :long double 类型浮点数。
• %n :已输出的字符串数量。该占位符本⾝不输出,只将值存储在指定变量之中。
• %o :⼋进制整数。
• %p :指针。
• %s :字符串。
• %u :⽆符号整数(unsigned int)。
• %x :⼗六进制整数。
• %zd : size_t 类型。
• %% :输出⼀个百分号。

printf

1.作用:

是将参数⽂本输出到屏幕。它名字⾥⾯的 f 代表 format (格式化),表⽰可以 定制输出⽂本的格式。

2.格式:

printf("a=%d", a);

在这里插入图片描述

3.与常见的占位符一起使用
(1)

整形:%d – int,%hd – short,%ld – long,%lld – long long 一起使用。
控制最小宽度:%md >> " m " 代表输出的最小宽度,如%2d>>输出最少两个数字,这里默认是右对齐想要左对齐就在%前面加 - ,如%-md

如:

int main() {int a = 10;short b = 110;long c = 222;long long d = 1234;printf("a=%d\n", a);printf("b=%hd\n", b);printf("c=%ld\n", c);printf("d=%lld\n", d);printf("2d=%8lld\n", d);//最小宽度为8,输出:“    1234”//向右对齐printf("-2d=%-8lld\n", d);//最小宽度为8,输出:“1234    ”//向左对齐return 0;
}

运行结果:
在这里插入图片描述
d和-2d看起来一样其实d=1234,-2d=1234(后面还有四个空格)。
(2)

浮点型:%f - fiaot、double,%lf - long double(后面默认有6位小数)
控制最小宽度和限定小数:%m .n f>> " m " 代表输出的最小宽度,如%2f最少输出两个数字,这里默认是右对齐想要左对齐就在%前面加 - ,如%-f,“. n”代表限定的小数个数,如%.3只能输出三个小数,其他用空格填补。

如:

int main() {double a = 12.34;float b = 23.45;long double c = 45.67;printf("a=%f\n", a);printf("b=%f\n", b);//默认6位printf("c=%lf\n", c);printf("2b=%.2f\n", b);//.2f--输出两位小数return 0;
}

运行结果:
在这里插入图片描述

(3)
整形字符输出 %c–char,%c是输出一个字符
最小宽度:%mc," m " 代表输出的最小宽度,其余规则和上面一样
如:

int main() {char a = 't';printf("%c\n", a);printf("%5c", a);//5--最小宽度return 0;
}

在这里插入图片描述
第2个 ‘ t ’由于宽度为5,默认右对齐所以前面补了4个空格
(4)

字符串输出%s–char[ ]
最小宽度与限定输出几个字符:%m.n s,“m”最小宽度,:n“限定输出几个字符

如:

int main() {char a[] = "abcdef";printf("%s\n", a);printf("%8s\n", a);//最小宽度为8printf("%.4s", a);//限定输出4位return 0;
}

运行结果:
在这里插入图片描述
第二个最小宽度为8,默认右对齐所以前面补了2个空格,第3个限定只输出前4个字符
4.多个占位符输出

注:多个占位符输出是一定要按照顺序来放变量

int main() {int a = 10;short b = 110;printf("a=%d b=%hd\n", a, b);return 0;
}

运行结果:
在这里插入图片描述

5.返回值

printf的返回值是输出字符的个数

如:

int main() {char a[] = "abcdef";
int  b=printf("%s\n", a);//一共有7个字符
printf("%d\n", b);//打印printf的返回值return 0;
}

运行结果:
在这里插入图片描述
abcdef–6个加上转义字符 \n 一共7个

scanf

scanf() 函数⽤于读取⽤⼾的键盘输⼊。程序运⾏到这个语句时,会停下来,等待⽤⼾从键盘输⼊。 ⽤⼾输⼊数据、按下回⻋键后, scanf() 就会处理⽤⼾的输⼊,将其存⼊变量。
注意:变量前⾯必须加上 & 运算符(指针变量除外),因为 scanf() 传递的不是值,⽽是地址,即将变量 i 的地址指向⽤⼾输⼊的值。如果这⾥的变量是指针变量(⽐如字符串变量),那就不⽤加 & 运算符。

2.格式

int a = 0;
scanf("%d", &a);

在这里插入图片描述

3.与常见的占位符一起使用
(1)

整形:%d – int,%hd – short,%ld – long,%lld – long long 一起使用。
控制输入宽度,%md,“m”是控制scanf的输入多少位

如:
这里举个int型的例子,short、long,也是和下面一样的只不过用的占位符有所差异

int main() {int a = 0;int b = 0;scanf("%2d ", &a);//限定输入两位printf("a=%d ", a);return 0;
}

运行结果:
在这里插入图片描述
由于限定了输入两位所以a的值只取了前两位,如果不限制的话a的值就是1234了
(2)

浮点型:%f - fiaot,%lf -、double, long double(后面默认有6位小数)
scanf()只能控制输入的宽度不能控制精度,控制宽度和整形一样

如:

int main() {double a = 0.0;scanf("%lf", &a);printf("a=%f ", a);return 0;
}

运行结果:
在这里插入图片描述
(3)

整形字符输出
%c–char,%c是输出一个字符,这个字符也可以是空格,tab,回车,当按回车就会结束,如果直接按回车,那么就会a=回车字符。
如果要强制跳过字符前的空⽩字符,可以写成 scanf(" %c", &ch) ,即 %c 前加上⼀个空格,表⽰跳过零个或多个空⽩字符。

int main() { 	char a ; scanf("%c", &a);printf("a=%c ", a);return 0; }

运行结果:
在这里插入图片描述
(4)

字符串输出%s–char[ ]
在字符串输入时遇到空格,tab,回车都会结束,所以scanf的字符串输入只能输入非空格,tab,回车的字符串
控制长度 :%ms,“m”代表接收多少个字符

如:

int main() {char a[127];scanf("%5s", &a);printf("a=%s ", a);return 0;
}

运行结果:
在这里插入图片描述
我们这里限定了5,所以只接收了5个字符,当然如果不限制的话就看字符数组长度了
4.多个占位符输出

多个值输入时也是按照顺序输入的

(1)当我们同时进行多个整形数据的输入时可以用空格、tab、回车来直接隔开,
如:

int main() {int a = 0;int b = 0;scanf("%d%d ", &a,&b);printf("a=%d b=%d", a,b);return 0;
}

运行结果:
在这里插入图片描述
我这里用的是回车,当然用tab ,空格也行
我们也可以用特殊的字符在scanf上对占位符隔开,但是在输入时隔开必须输入与scanf一样字符
如:
这里我们用 - 隔开

int main() {int a = 0;int b = 0;scanf("%d-%d", &a,&b);printf("a=%d b=%d", a,b);return 0;
}

当我们不按照scanf上的字符输入时:
![在这里插入图片描述](https://img-blog.csdnimg.cn/a1467ba55c834aa580589f6f0ebf93c5.png
这里用空格,很明显出现问题了,b的值就没有输入
当我们按照scanf上的输入时:
在这里插入图片描述
这样就没问题啦
(2)当字符和整数一起输入时,不用加空格等将它们隔开,因为编译器会识别
我们了来试试吧

int main() {char a ;int b = 0;scanf("%c%d", &a, &b);printf("a=%c b=%d", a, b);return 0;
}

运行结果:
在这里插入图片描述
(3)
整形与字符串
整形与字符串在一起时必须用空格、tab、回车来隔开,不能像整形和整形那样用特殊字符来隔开
如:

int main() {char a[128] ;int b = 0;scanf("%s-%d", &a, &b);printf("a=%s b=%d", a, b);return 0;
}

用特殊字符隔开
在这里插入图片描述
特殊字符被当作一个字符用了,所以一定要用空格、tab、回车来隔开

int main() {char a[128] ;int b = 0;scanf("%s%d", &a, &b);printf("a=%s b=%d", a, b);return 0;
}

不用特殊字符隔开
运行结果:
在这里插入图片描述

(4)
浮点型和整形一起的话就是与整形和整形一样
浮点型和字符一起的话就是与整形和字符一样
浮点型和字符串一起的话就是与整形和字符串一样

5.赋值忽略符

赋值忽略符(*)
用在%与字母中间,如:%*b
作用:忽略在输入的值

如:

int main() { 	int a = 0; int b = 0; 	scanf("%d%*d%d", &a, &b);//这样第二个输入的值就会被忽略掉 printf("a=%d b=%d", a, b); return 0;
}

运行结果:
在这里插入图片描述

这样上第二个值44就被忽略了

返回值

scanf() 的返回值是⼀个整数,表⽰成功读取的变量个数。 如果没有读取任何项,或者匹配失败,则返回 0。如果在成功读取任何数据之前,发⽣了读取错误或 者遇到读取到⽂件结尾,则返回常量 EOF。

如:

int main() {int a = 0;int b = 0;int t=scanf("%d%d", &a, &b);printf("a=%d b=%d\n", a, b);printf("t=%d", t);//返回值return 0;
}

运行结果:
在这里插入图片描述

字符串输入输出

puts()

作用:输出字符串,并自动换行
格式:puts();()里可以是一个字符串,也可以是字符串数组
使用:

int main() {char arr[] = "asjfil";puts(arr);int  t = puts("fjsdfjs");printf("t=%d", t);//返回值return 0;
}

运行结果:
![在这里插入图片描述](https://img-blog.csdnimg.cn/c0d6c360a60043b59ab8703cb8854938.png

返回值为 0 ,并且自动换行了

gets()

作用:输入字符串,并且能够接收空格,tab,当遇到回车时结束,字符串是回车之前的字符
格式:gets();,括号里放字符数组
使用:

int main() {char arr[30] ;int t=gets(arr);puts(arr);printf("t=%d", t);//返回值return 0;
}

运行结果:
在这里插入图片描述
返回值为随机值,并且能接收空格了

字符输入输出

putchar()

作用:输出一个字符(这个字符也可以是转义字符)
格式:putchar();()里可以放字符变量和一个字符
使用:

int main() {char a='w';int t = putchar(a);putchar('\n');putchar('w');putchar('\n');//转义字符printf("t=%d", t);//返回值return 0;
}

运行结果:
在这里插入图片描述
返回值为字符的ascll值

getchar()

作用:输入一个字符
格式: char a=getchar();
使用:

int main() {char a ;
a =getchar();putchar(a);putchar('\n');return 0;
}

在这里插入图片描述
getchar函数只以回车、Enter结束输入,接受空格符。

区别

printf 和 puts

在输出整数浮点数时只能用printf
在输出字符串时就是puts会自动换行,其他没区别了

printf和putchar

在输出整数浮点数时只能用printf
在输出一个字符时没区别

scanf和gets

在输入整数浮点数时只能用scanf
在输入字符串时scanf不能接收空格、tab,而gest可以接收,并且可以抛弃最后的回车,而scanf不会抛弃,会将空格、tab,回车存在缓冲区里,下次还要输出字符时用调用

如:

int main() {char a ;char b;scanf("%c",&a);//输入一个字符scanf("%c", &b);//看看b是否调用空格printf("%d %d", a, b);//打印ascii码return 0;
}

运行结果:
在这里插入图片描述
空格的ASCII就是32,所以scanf会调用上一次留下的字符

scanf和getchar

在输入整数浮点数时只能用scanf scanf遇到 回车(enter),空格,TAB 就会结束一次输入,不会接收空格。
getchar函数只以回车、Enter结束输入,接受空格符。 scanf在一次输入结束后,不会舍弃最后的回车符(即回车符会残留在缓冲区中) getchar回车作为结束的标志,所以在敲回车时’\n’也被存入缓存区,下次还要输出字符时用调用(这个和上的是一个道理哦)

以上就是我的分享,谢谢大家观看!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/195957.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

原理Redis-动态字符串SDS

动态字符串SDS Redis中保存的Key是字符串&#xff0c;value往往是字符串或者字符串的集合。可见字符串是Redis中最常用的一种数据结构。 不过Redis没有直接使用C语言中的字符串&#xff0c;因为C语言字符串存在很多问题&#xff1a; 获取字符串长度的需要通过运算非二进制安全…

(数据库管理系统)DBMS与(数据库系统)DBS的区别

数据库管理系统&#xff08;DBMS&#xff0c;Database Management System&#xff09;和数据库系统&#xff08;DBS&#xff0c;Database System&#xff09;是两个相关但不同的概念。 DBS是一个更广泛的概念&#xff0c;指的是计算机系统引入数据库后的系统&#xff0c;包括数…

PgSQL技术内幕-Bitmap Index Scan

PgSQL技术内幕-Bitmap Index Scan 1、简介 Bitmap索引扫描是对索引扫描的一个优化&#xff0c;通过建立位图的方式将原来的随机堆表访问转换成顺序堆表访问。主要分为两点&#xff1a;1&#xff09;管理每个Bitmap的hash slot没用完时&#xff0c;每个Bitmap代表每个heap页中满…

nn.KLDivLoss,nn.CrossEntropyLoss,nn.MSELoss,Focal_Loss

KL loss&#xff1a;https://blog.csdn.net/qq_50001789/article/details/128974654 https://pytorch.org/docs/stable/nn.html 1. nn.L1Loss 1.1 公式 L1Loss: 计算预测 x和 目标y之间的平均绝对值误差MAE, 即L1损失&#xff1a; l o s s 1 n ∑ i 1 , . . . n ∣ x i…

【Flink】系统架构

DataStream API 将你的应用构建为一个 job graph&#xff0c;并附加到 StreamExecutionEnvironment 。当调用 env.execute() 时此 graph 就被打包并发送到 JobManager 上&#xff0c;后者对作业并行处理并将其子任务分发给 Task Manager 来执行。每个作业的并行子任务将在 task…

矩阵运算_矩阵的协方差矩阵/两个矩阵的协方差矩阵_求解详细步骤示例

1. 协方差矩阵定义 在统计学中&#xff0c;方差是用来度量单个随机变量的离散程度&#xff0c;而协方差则一般用来刻画两个随机变量的相似程度。 参考&#xff1a; 带你了解什么是Covariance Matrix协方差矩阵 - 知乎 2. 协方差矩阵计算过程 将输入数据A进行中心化处理得到A…

【开源】基于Vue.js的创意工坊双创管理系统

项目编号&#xff1a; S 049 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S049&#xff0c;文末获取源码。} 项目编号&#xff1a;S049&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 管理员端2.2 Web 端2.3 移动端 三、…

你知道什么是SaaS吗?

你知道什么是SaaS吗&#xff1f; 云服务架构的三个概念 PaaS 英文就是 Platform-as-a-Service&#xff08;平台即服务&#xff09;PaaS&#xff0c;某些时候也叫做中间件。就是把客户采用提供的开发语言和工具&#xff08;例如Java&#xff0c;python, .Net等&#xff09;开…

【每日一题】三个无重叠子数组的最大和

文章目录 Tag题目来源题目解读解题思路方法一&#xff1a;滑动窗口 写在最后 Tag 【滑动窗口】【数组】【2023-11-19】 题目来源 689. 三个无重叠子数组的最大和 题目解读 解题思路 方法一&#xff1a;滑动窗口 单个子数组的最大和 我们先来考虑一个长度为 k 的子数组的最…

Redux-状态管理组件

一、简介 react中的状态只属于某个组件。而Redux是一个全局管理js状态的架构&#xff0c;让组件通信更加容易。 之前是状态在所有组件间传递&#xff0c;而redux通过store来实现这个功能。 Redux特性&#xff1a; 1.Single source Of truth&#xff0c;通过store唯一维护状态…

电子学会C/C++编程等级考试2022年03月(一级)真题解析

C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…

【Android】使用Retrofit2发送异步网络请求的简单案例

添加网络权限到AndroidManifest.xml清单文件 为了让你的Android应用程序能够使用互联网进行通信&#xff0c;你需要在AndroidManifest.xml文件中添加网络权限声明。<uses-permission android:name"android.permission.INTERNET"/> 这个权限应该添加到 Android…