2023-04-16 学习记录--C/C++-邂逅C/C++(上)

本文介绍了C语言的基础知识,包括<stdio.h>库的使用,printf和scanf函数的详细用法,如换行符 、制表符 和回车符 的作用,以及int、float、double、char数据类型的输出和输入方法。还提到了ASCII码表和getchar()、putchar()函数的功能,以及涉及数学运算和格式化输出的相关知识点。
摘要由CSDN通过智能技术生成

合抱之木,生于毫末;九层之台,起于累土;千里之行,始于足下。💪🏻

一、固定格式 ⭐️

在这里插入图片描述

stdio的理解: abbr.标准输入输出(standard input/output)。

#include <stdio.h>
int main()
{
   ... // 表达式
   return 0;
}

二、printf语句(输出语句) ⭐️

在这里插入图片描述

(一)、前提【重要

(仅个人初学者用来记忆所用,待学有所长后会完善更新这部分内容,谢谢评论里滴小阔耐指出💐)

注意:对于最后一个输出的语句,必须在后面加上\n换行符),不然输出结果后面会默认加个%,如下举例:👇🏻

1、不推荐写法 ❎
#include <stdio.h>
int main()
{
    printf("我们来学习C/C++呀"); // 我们来学习C/C++呀%【注意:对于最后一个输出的语句,必须在后面加上\n(换行符),不然输出结果后面会默认加个%】
    return 0;
}
#include <stdio.h>
int main()
{
    printf("我们来学习");
    printf("C/C++呀"); // 我们来学习C/C++呀%【注意:对于最后一个输出的语句,必须在后面加上\n(换行符),不然输出结果后面会默认加个%】
    return 0;
}

在这里插入图片描述

2、推荐写法 ✅
#include <stdio.h>
int main()
{
    printf("我们来学习C/C++呀\n"); // 加上换行符\n
    return 0;
}
#include <stdio.h>
int main()
{
    printf("我们来学习");
    printf("C/C++呀\n"); // 加上换行符\n
    return 0;
}

在这里插入图片描述

(二)、换行符(\n

\nnext line,表示换行操作,光标移动到下一行。

#include <stdio.h>
int main()
{
    printf("我们来学习\nC/C++呀\n");
    return 0;
}
#include <stdio.h>
int main()
{
    printf("我们来学习\n");
    printf("C/C++呀\n");
    return 0;
}

在这里插入图片描述

(三)、制表符(\t

\ttab,表示水平制表空行操作,相当于键盘上的Tab键,不会换行。

#include <stdio.h>
int main()
{
    printf("我们来学习\tC/C++呀\n");
    return 0;
}
#include <stdio.h>
int main()
{
    printf("我们来学习\t");
    printf("C/C++呀\n");
    return 0;
}

在这里插入图片描述

(四)、回车符(\r

\rreturn,表示回车操作,光标回到本行首位置,不会换行;

三、intfloatdoublechar型数据 ⭐️

在这里插入图片描述

  1. int:整数型,用于定义整数类型的数据;int a = 3;
  2. float:单精度浮点型,准确到小数点后六位;float a = 3.14;
  3. double:双精度浮点型,准确到小数点后十二位;double a = 3.14;
  4. char:字符型,用于定义字符类型的数据。char a = 'A';注意:单引号

四、用printf语句输出intfloatdoublechar型数据 ⭐️

在这里插入图片描述

  1. 整数型(int):%d
  2. 单精度浮点型、双精度浮点型(floatdouble):%f
  3. 字符型(char):%c
    在这里插入图片描述
#include <stdio.h>
int main()
{
    /** 使用变量前必须先定义 */
    int a = 5, b;
    double c = 3.14, d;
    char e = 'E', f;
    /** 计算 */
    b = a % 2;  // 求余数 5%2=1
    d = c * 2;  // 6.280000
    f = e + 32; // 'e' 【ASCII码表中,大写字母在前,小写字母在后;大写字母与小写字母的ASCII码值相差32:大写字母+32=小写字母,小写字母-32=大写字母】
    /** 输出结果 */
    printf("b的值为%d\n", b); // int -> %d
    printf("d的值为%f\n", d); // double -> %f
    printf("f的值为%c\n", f); // char -> c%【对于最后一个输出的语句,必须在后面加上\n(换行符)】
    return 0;
}

在这里插入图片描述

补充知识点:💐

  • ASCII码表中,大写字母在前,小写字母在后;
  • 大写字母与小写字母的ASCII码值相差32大写字母+32=小写字母小写字母-32=大写字母

五、用scanf语句输入intfloatdoublechar型数据 ⭐️

1、作用 🌈:scanf语句是让用户输入内容。
2、举例 📚:(让用户输入两个整数型变量:a,b)

  • int a,b; // 自定义整数型变量a b
  • scanf("%d,%d",&a,&b); // 题目让输入几个整数,就写几个%d;引号里面有几个%d,引号外面对应有几个变量,变量前加个&符号。
  1. 整数型(int):%d
  2. 单精度浮点型(float):%f
  3. 双精度浮点型(double):%lf
  4. 字符型(char):%c
    在这里插入图片描述
#include <stdio.h>
int main()
{
    /** 使用变量前必须先定义 */
    int a;    // 整数型
    float b;  // 单精度浮点型型
    double c; // 双精度浮点型型
    char d;   // 字符型
    /** 让用户输入对应值 */
    printf("请输入一个整数值a:\n");
    scanf("%d", &a); // scanf里:int -> %d
    printf("请输入一个小数值b:\n");
    scanf("%f", &b); // scanf里:float ->%f
    printf("请输入一个小数值c:\n");
    scanf("%lf", &c); // scanf里:double -> %lf
    printf("请输入一个字符d:\n");
    scanf("%c", &d); // scanf里:char -> %c
    d = getchar(); // 把键盘输入的第1个字符赋值给变量d。由于缓冲区问题,若不加上这段代码,在输出时,scanf("%c", &d);这行代码会失效,具体解释见下方
    /** 输出结果 */
    printf("a的值为%d\n", a); // printf里:int -> %d
    printf("b的值为%f\n", b); // printf里:float ->%f
    printf("c的值为%f\n", c); // printf里:double -> %f
    printf("d的值为%c\n", d); // printf里:char -> %c
    return 0; // 程序正常运行结束
}

重点】需要注意的是,在读取字符型变量时,可能会遇到缓冲区的问题。由于之前的输入会在缓冲区中留下 换行符,因此在读取字符型变量时,可能会直接读取到换行符,导致 输出不符合预期。可以在读取字符型变量前加入getchar()函数来 清除缓冲区中的换行符,例如 scanf("%c", &d);d =getchar();

在这里插入图片描述

六、getchar()语句、putchar()语句 ⭐️

  1. getchar():从键盘上得到某一个字符;
  2. putchar():把某一个字符呈现到屏幕上。

在这里插入图片描述

#include <stdio.h>
int main()
{
    /** 使用变量前必须先定义 */
    char a, b, c; // 定义3个字符a b c
    /** 让用户输入对应值 */
    printf("请输入您的英文名大写:\n");
    a = getchar(); // 键盘输入的第1个字符赋值给变量a
    b = getchar(); // 键盘输入的第2个字符赋值给变量b
    c = getchar(); // 键盘输入的第3个字符赋值给变量c
    /** 计算 */
    a = a + 32; // 转换成小写字母
    b = b + 32; // 转换成小写字母
    c = c + 32; // 转换成小写字母
    /** 输出结果 */
    putchar(a);    // 输出字符变量a
    putchar(b);    // 输出字符变量b
    putchar(c);    // 输出字符变量c
    putchar('\n'); // 输出换行符(用的单引号)【对于输出型语句,最后一条输出语句的末尾需输出换行符(\n)】
    /** 程序正常运行结束 */
    return 0;
}

在这里插入图片描述

七、数学运算 ⭐️

在这里插入图片描述

详情请查看我的另一篇博文哦~

八、三个小知识点 ⭐️

(一)、%m.nf

%m.nf:表示输出的数字总共占m个格,其中小数点后占n个格。

若输出后 数字占格不够,其处理步骤是:💐

  • 第1步📚、观察小数点后占格是否等于n,若不等于,就在小数点后的值后面补所需个数的0
  • 第2步📚、在第1步处理后的基础上,计算数字总占格数是否等于m,若不等于,则 判断m的正负
    • 1、若m,在数字补所需个数的空格
    • 2、若m,在数字补所需个数的空格
example1:🎈

举例 🌈:double a=3.67; printf("输出的a为%7.4f\n",a);
推论 📚:由已知条件可知:m=7>0n=4,通过上面处理步骤可知:3.67需补两个03.6700需补一个空格,所以最终结果为:
结果 💐:输出的a为 3.6700

#include <stdio.h>
int main()
{
    /** 使用变量前必须先定义 */
    double a = 3.67;
    /** 输出结果 */
    printf("输出的a为%7.4f\n", a); // 记得加换行符\n
    /** 程序正常运行结束 */
    return 0;
}

在这里插入图片描述

example2:🎈
#include <stdio.h>
int main()
{
    /** 使用变量前必须先定义 */
    double a, b, c;
    /** 赋值 */
    a = 3.67;
    b = 5.43;
    c = 6.21;
    /** 输出结果 */
    printf("设定的是%5.2f,b是%-5.2f,c是%7.4f\n", a, b, c); // 记得加换行符\n
    /** 程序正常运行结束 */
    return 0;
}

在这里插入图片描述
在这里插入图片描述

(二)、%e

1、%e的定义

%e:以科学计数法的形式来表现。
%e默认 小数点后面6位数,然后e+0几总共占4个格。

在这里插入图片描述

比如 🌈:printf("身高是%e厘米\n", 123.456);
推论 📚:

  • 因为:10^2=e+02, 10^3=e+03。。。以此类推;
  • 所以123.456=1.23456*10^2=1.23456e+02(未完);
  • 又因为 “%e默认小数点后面取6位数,然后e+0几总共占4个格。”,而1.23456小数点后是5位,
  • 所以需在6后面补个0,即上面=1.234560e+02。

最终结果为 💐:身高是1.234560e+02厘米

#include <stdio.h>
int main()
{
    /** 输出结果 */
    printf("身高是%e厘米\n", 123.456); // 记得加换行符\n
    /** 程序正常运行结束 */
    return 0;
}

在这里插入图片描述

2、%e之间也可以加小数表示限制

在这里插入图片描述

比如 🌈:printf("身高是%10.2e厘米\n", 123.456);
推论 📚:%10.2e表示总共10格,小数点后占2格;又因为1.23e+02占了8格 且 10>0,所以还需在前面补两个空格
最终结果 💐:身高是 1.23e+02厘米

#include <stdio.h>
int main()
{
    /** 输出结果 */
    printf("身高是%10.2e厘米\n", 123.456); // 记得加换行符\n
    /** 程序正常运行结束 */
    return 0;
}

在这里插入图片描述

(三)、(int)(表达式)

(int)(表达式):将表达式结果强制转成整形(即抹去表达式结果中的小数点,向下取整)。

example1:🎈

题目:求9999.999的千位数。

#include <stdio.h>
int main()
{
    /** 使用常量/变量前必须先定义 */
    float a = 9999.999; // 自定义常量a
    int b;              // 自定义变量b
    /** 计算 */
    b = (int)(a / 1000);
    /** 输出结果 */
    printf("%f的千位数是%d\n", a, b); // 记得加换行符\n
    /** 程序正常运行结束 */
    return 0;
}

在这里插入图片描述

example2:🎈

题目:输入一个大于0小于999的可以带小数的数字,并输出其个位、十位以及百位数字。

#include <stdio.h>
int main()
{
    /** 使用常量/变量前必须先定义 */
    double a;         // 自定义一个大于0小于999可为小数的值a
    int ge, shi, bai; // 自定义变量ge(个位数)、shi(十位数)、bai(百位数)
    /** 用户输入 */
    printf("请输入一个大于0小于999可为小数的值:\n"); // 提示信息
    scanf("%lf", &a); // 用户输入a的值
    /** 计算 */
    bai = (int)(a / 100); // 因为a最多是3位数,所有先求出它的百位数 eg. 321.1/100=3.211;(int)(3.211)=3 即321.1的百位数是3
    shi = (int)((a - bai * 100) / 10);
    ge = (int)(a - bai * 100 - shi * 10);
    /** 输出结果 */
    printf("个位数字%d\n", ge);
    printf("十位数字%d\n", shi);
    printf("百位数字%d\n", bai); // 记得加换行符\n
    /** 程序正常运行结束 */
    return 0;
}

在这里插入图片描述

下一篇:邂逅C/C++(中)

【注意】涉及计算的变量一定要给初始值。

在这里插入图片描述

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小呀小萝卜儿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值