当前位置: 首页 > article >正文

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

一、固定格式 ⭐️

在这里插入图片描述

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;
}

在这里插入图片描述

在这里插入图片描述


http://www.kler.cn/news/10428.html

相关文章:

  • 这篇文章价值很大:股票历史分时成交数据怎么简单获取?【干货】
  • 2023年七大最佳勒索软件解密工具
  • C#基础复习
  • 轨道交通信号系统介绍
  • 学术论文句式整理(持续更新中)
  • 【C++进阶】function和bind及可变模板参数
  • SpringBoot使用Spring Validation案例
  • AXI write data在Write data channel的排布
  • HR:面试官最爱问的linux问题,看看你能答对多少
  • 推荐一款 AI 脑图软件,助你神速提高知识体系搭建
  • C++中的类模版
  • 已知原根多项式和寄存器初始值时求LFSR的简单例子
  • C学习笔记1
  • 【安全与风险】恶意软件:概念、攻击和检测
  • 走进小程序【七】微信小程序【常见问题总结】
  • 反序列化渗透与攻防(二)之Java反序列化漏洞
  • 对 FLAG_ACTIVITY_NEW_TASK | FLAG_ACTIVITY_CLEAR_TOP 的实践
  • 这家年销售额309亿的Tier 1,要谈一场千亿新生意
  • 【软考备战·希赛网每日一练】2023年4月12日
  • apache配置与应用
  • ChatGPT实战100例 - (01) 秒出思维导图
  • 程序员的“灵魂笔记本“:五款高效笔记软件推荐
  • 线程池
  • WinForms 网格控件 - iGrid.NET 10.1.22 Crack
  • 1.java程序员必知必会类库之日志
  • Windows使用Dockers+battery historian踩坑记
  • HTTP 和 HTTPS 的区别
  • 基于Vue3封装一个好用的Websocket
  • 男生|女生漫画头像怎么制作,分享3种免费制作方法,不用求人
  • rstudio跑不动咋整?-------生信豆芽菜