第三节课 笔记
printf函数
纯纯的打印函数 没啥好说
格式
printf("转换说明",变量名); // 转换说明要和变量的类型相对应哟!多个变量名 对应多个转换说明 逗号排序
转换说明
%d 输出整型
%lf 输出double
%f 输出float
%c 输出字符——char
%s 输出字符串 ——char*
特殊字符
ps:打印 “/” 需要输入//
同理,打印"%" 需要输入%%
精度控制
举个栗子
%5d 显示至少5位的十进制整数
%5.1f 显示至少五位的浮点数
%AB.CD
A:0标志 ,可省略
B:最小字符数
C:精度
D:转换说明符
制表
八位制表,不够补空格 (汉字占两个字节,字母占一个字节)
转义制表字符——\t
超过八位的情况下——按照十六位制表
printf(“内容/t内容/t内容/t”);
putchar函数
专门输出一个字符 不用写转换说明
格式:
putchar('');
puts函数
打印字符串
puts(""); //自带换行
数据类型
int 整型(整数) float 单精度浮点数 double 双精度浮点数
char 字符 long 和 short 整数(范围大小不同)
scanf函数
输入函数格式 scanf(“转换说明”,&变量名)
-
只有vs可以用scanf_s
-
忽略警告 或者 处理 scanf没有返回值方法: 随便整一个变量=scanf(~~)
计算机输入过程:
键盘输入——缓冲区——scanf函数输入(获取变量的地址)
跳过现象
即在字符和字符串输入之前,做了输入
那么会跳过字符和字符串的输入
原因:scanf函数通过格式控制获取字符,所以每次回车执行后,字符会提取出缓冲区,而\n仍会留在缓冲区。(咱就是说,sacnf自带\n)
清空缓冲区
while("getchar()!='\n'"); //直到输入回车键才退出循环
//只有在字符输入前做了输入才需要
尺寸限制
因为字符只占1个字节
因此输入字符时候需要做尺寸限制
scanf(“%c”,&变量名,1);
获取变量存储地址
取地址符——&
&变量名——printf:输出内存地址
getchar函数
字符的输入
getch函数
特殊字符输入:不需要回车键确认的输入
-
需要头文件 <conio.h>
字符变量名=_getch(); //vs需要加下划线
类型转换
隐式转换
特点:内存长转换为内存短的会存在精度丢 失的现象(隐式转换)
短往长的转莫有影响
转换方式如下
int num=1.33f;
float fnum=3;
强制类型转换
语法:(要转换的类型)要转换的目标
int a= 1 ;
int b= 2 ;
prtinf("%lf",(double) a + b);//将a+b的结果从int类型转换为double类型(同样注意是否存在精度丢失的问题)
ASCII转换——整数与字符之间的转换
num='A';
printf("%d",num);
填空题
-
标识符可由,,组成,但是首字符不能是
字母 数字 下划线 字母
-
C语言中常用的标识符命名规范是____________
大驼峰 小驼峰 匈牙利
-
整数 520 默认的类型是____________ int
-
浮点型 3.14 默认的类型是____________ double
-
有一个输出语句 printf(“%d”,3.14); 这个输出语句是否正确输出的结果有没有意义
不正确 没意义,整型输出忽略小数位
-
类型大小:计算机类型为32位
- char ____________字节 1
- short ____________字节 2
- int ____________字节 4
- long int ____________字节 4
- long long ____________字节 8
- float ____________字节 4
- double ____________字节 8
- unsigned int ____________字节 4
编程题
- 编程实现输入一个字符,若字符是大写字母则转小写输出,如是小写字母则转大写字母输出,不是字符直接输出。
源码如下
#include <stdio.h>
int main()
{
char x;
puts("请输入一个字母");
scanf("%c", &x,1); //内存尺寸的限制
if (x >= 65 && x <= 90) //对应ACSII表与整数的相互转换
{
printf("%c", x + 32);
}
else if (x >= 97 && x <= 122)
{
printf("%c", x - 32);
}
else
printf("%c", x);
return 0;
}