C语言入门课程学习笔记8:变量的作用域递归函数宏定义交换变量

C语言入门课程学习笔记8

  • 第36课 - 变量的作用域与生命期(上)
  • 第37课 - 变量的作用域与生命期(下)
    • 实验—局部变量的作用域
    • 实验-变量的生命期
  • 第38课 - 函数专题练习
  • 第39课 - 递归函数简介
    • 实验-递归
    • 小结
  • 第40课 - C 语言中的宏定义
    • 实验-红实现交换
    • 小结

第36课 - 变量的作用域与生命期(上)

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

#include <stdio.h>int var = 100;  // 全局变量void f(int var) // var <==> 局部变量
{var++;printf("var = %d\n", var);
}int main()
{int var = 10;  // 局部变量f(var);  // f(10);printf("var = %d\n", var);  // var = 10;return 0;
}
// var = 11
// var = 10

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

#include <stdio.h>int var = 100;  // 全局变量int main()
{int var = 10;  // 局部变量{int var = 1;  // 局部变量printf("var = %d\n", var);}printf("var = %d\n", var);  // var = 10;return 0;
}
var = 1
var = 10
#include <stdio.h>int main()
{int i = 0;  // 局部变量while( i < 5 ){int j = 10;  // 局部变量j++;printf("j = %d\n", j);i++;}printf("i = %d\n", i);  // var = 10;return 0;
}
/*
j = 11
j = 11
j = 11
j = 11
j = 11
i = 5
*/

在这里插入图片描述

第37课 - 变量的作用域与生命期(下)

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

实验—局部变量的作用域

#include <stdio.h>int var = 1;//全局变量void func()
{printf("var = %d\n", var);
}int main()
{int var = 2;//局部变量1int i = 0;for(i=0; i<5; i++){int var = 4;//局部变量2,作用域只在{}内var += i;printf("var = %d\n", var);}func();//函数调用,打印的是全局变量printf("var = %d\n", var);//局部变量1return 0;
}
/*
var = 4
var = 5
var = 6
var = 7
var = 8
var = 1
var = 2*/

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

实验-变量的生命期

#include <stdio.h>int g_var = 1;
static int g_sVar = 2;int main()
{static int s_var = 3;auto int v = 4;register int rv = 5;printf("g_var = %d\n", g_var);//1printf("g_sVar = %d\n", g_sVar);//2printf("s_var = %d\n", s_var);//3printf("v     = %d\n", v);//4printf("rv    = %d\n", rv);//5return 0;
}

在这里插入图片描述

第38课 - 函数专题练习

在这里插入图片描述
编译通过,有警告,编译器默认为int
B
如果改成int func(float var){var+=1;} ,返回随机值
在这里插入图片描述
C
在这里插入图片描述
x=5,y=8, 13+7
B
搞错了z–是先取值,再减一
C 13+8
在这里插入图片描述
A
在这里插入图片描述

在这里插入图片描述
A
在这里插入图片描述
12
15

在这里插入图片描述
8 10

4

在这里插入图片描述

DELPHI TANG

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

#include <stdio.h>int getNumber(char c)//字符转换为数字
{int ret = -1;if( ('0' <= c) && (c <= '9') )ret = c - '0';return ret;
}int str2int(char str[])
{int ret = 0;int sign = 0;int i = 0;//首个数字的位置if( getNumber(str[0]) != -1 )//是数字 符号为+{sign = 1;i = 0;}else if( str[0] == '+' )//{sign = 1;i = 1;}else if( str[0] == '-' ){sign = -1;i = 1;}while( sign && str[i] ){int n = getNumber(str[i]);if( n != -1 )ret = ret * 10 + n;elsebreak;i++;}ret = sign * ret;return ret;
}int main()
{printf("%d\n", str2int("123"));printf("%d\n", str2int("-12345"));printf("%d\n", str2int("567xyz89"));printf("%d\n", str2int("abc"));printf("%d\n", str2int("-xyz"));return 0;
}

第39课 - 递归函数简介

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

实验-递归

#include <stdio.h>int sum(int n)
{int ret = 0;if( n == 1 )ret = 1;elseret = n + sum(n-1);return ret;
}int fac(int n)
{int ret = 0;if( n == 1 )ret = 1;else if( n == 2 )ret = 1;else if( n >= 3 )ret = fac(n-1) + fac(n-2);elseret = -1;return ret;
}int main()
{int i = 0;printf("sum(1) = %d\n", sum(1));printf("sum(10) = %d\n", sum(10));printf("sum(100) = %d\n", sum(100));for(i=1; i<=10; i++){printf("%d, ", fac(i));}printf("\n");return 0;
}

小结

在这里插入图片描述

第40课 - C 语言中的宏定义

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

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

实验-红实现交换

#include <stdio.h>#define ADD(a, b) a + b#define SWAP(a, b)  {int t = a; a = b; b = t;}#define MIN(a, b) (a < b ? a : b)void swap(int a, int b)
{int t = 0;// printf("a = %d, b = %d\n", a, b);t = a;a = b;b = t;// printf("a = %d, b = %d\n", a, b);}int main()
{int x = 1;int y = 2;printf("x = %d, y = %d\n", x, y);SWAP(x, y);   // {int t = x; x = y; y = t;}printf("x = %d, y = %d\n", x, y);printf("x + y = %d\n", ADD(x, y));printf("MIN(%d, %d) = %d\n", x, y, MIN(x, y));  // printf("MIN(%d, %d) = %d\n", x, y, (x < y ? x : y));return 0;
}

在这里插入图片描述

小结

在这里插入图片描述

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

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

相关文章

C语言 while循环1

在C语言里有3种循环&#xff1a;while循环 do while 循环 for循环 while语句 //while语法结构 while&#xff08;表达式&#xff09;循环语句; 比如在屏幕上打印1-10 在while循环中 break用于永久的终止循环 在while循环中&#xff0c;continue的作用是跳过本次循环 …

如何安全进行亚马逊、沃尔玛测评?

在亚马逊、沃尔玛、速卖通、阿里国际站等电商平台上&#xff0c;测评已成为一种高效的推广手段&#xff0c;但伴随的风险也不容忽视。这些风险主要源于平台严格的大数据风控机制&#xff0c;它涵盖了多个方面&#xff0c;以确保评价的真实性和合规性。 首先&#xff0c;硬件参数…

Avalonia 常用控件二 Menu相关

1、Menu 添加代码如下 <Button HorizontalAlignment"Center" Content"Menu/菜单"><Button.Flyout><MenuFlyout><MenuItem Header"打开"/><MenuItem Header"-"/><MenuItem Header"关闭"/&…

Unity贪吃蛇改编【详细版】

Big and small greedy snakes 游戏概述 游戏亮点 通过对称的美感&#xff0c;设置两条贪吃蛇吧&#xff0c;其中一条加倍成长以及加倍减少&#xff0c;另一条正常成长以及减少&#xff0c;最终实现两条蛇对整个界面的霸占效果。 过程中不断记录两条蛇的得分情况&#xff0c…

如何配置taro

文章目录 step1. 全局安装wepacksetp2. 使用npm安装tarostep3. 项目初始化 使用taro时需要在本地配置好nodejs环境&#xff0c;关于如何配置nodejs可参考我的这篇博文 如何配置nodejs环境 step1. 全局安装wepack 使用指令npm install webpack -g即可 安装完成后可看到有wepa…

十大经典排序算法——选择排序和冒泡排序

一、选择排序 1.基本思想 每一次从待排序的数据元素中选出最小&#xff08;或最大&#xff09;的一个元素&#xff0c;存放在序列的起始位置&#xff0c;直到全部待排序的数据全部排完。 2.直接选择排序 (1) 在元素集合arr[i] — arr[n - 1]中选择关键妈的最大&#xff08;小…

GaussDB关键技术原理:高性能(二)

GaussDB关键技术原理&#xff1a;高性能&#xff08;一&#xff09;从数据库性能优化系统概述对GaussDB的高性能技术进行了解读&#xff0c;本篇将从查询处理综述方面继续分享GaussDB的高性能技术的精彩内容。 2 查询处理综述 内容概要&#xff1a;本章节介绍查询端到端处理的…

AI大模型企业应用实战(18)-“消灭”LLM幻觉的利器 - RAG介绍

大模型在一定程度上去改变了我们生活生工作的思考的方式&#xff0c;然后也越来越多的个人还有企业在思考如何将大模型去应用到更加实际的呃生产生活中去&#xff0c;希望大语言模型能够呃有一些更多企业级别生产落地的实践&#xff0c;然后去帮助我们解决一些业务上的问题。目…

汉语拼音字母表 (声母表和韵母表)

汉语拼音字母表 [声母表和韵母表] 1. 汉语拼音声母表2. 汉语拼音韵母表References 1. 汉语拼音声母表 声母是韵母前的辅音&#xff0c;与韵母一起构成一个完整的音节。 辅音是发声时&#xff0c;气流在口腔中受到各种阻碍所产生的声音&#xff0c;发音的过程即是气流受阻和克…

玩转Matlab-Simscape(初级)- 10 - 基于COMSOLSimulink 凸轮机构的控制仿真

** 玩转Matlab-Simscape&#xff08;初级&#xff09;- 10 - 基于COMSOL&Simulink 凸轮机构的控制仿真 ** 目录 玩转Matlab-Simscape&#xff08;初级&#xff09;- 10 - 基于COMSOL&Simulink 凸轮机构的控制仿真 前言一、简介二、在Solidworks中创建3D模型&#xff…

Springboot拦截器使用及其底层源码剖析

博主最近看了一下公司刚刚开发的微服务&#xff0c;准备入手从基本的过滤器以及拦截器开始剖析&#xff0c;以及在帮同学们分析一下上次的jetty过滤器源码与本次Springboot中tomcat中过滤器的区别。正题开始&#xff0c;拦截器顾名思义是进行拦截请求的一系列操作。先给大家示例…

H4020 12V24V36V40V1A 同步降压芯片IC Buck-DCDC 低功耗,高效率 100%占空比

H4020是一款12V24V36V40V1A的同步降压&#xff08;Buck&#xff09;DC-DC转换器&#xff0c;专为需要高效率、低功耗和精确电压/电流控制的应用而设计。它内置了高压MOSFET&#xff0c;支持宽范围的输入电压&#xff08;5V-36V&#xff09;&#xff0c;并能提供高达1A的持续输出…

汇编快速入门

一.基础知识 1.数据类型 DB&#xff08;Define Byte&#xff0c;字节类型 占位8位bit 1字节&#xff09; 范围&#xff1a;DB可以用来定义&#xff08;无符号、有符号&#xff09;整数&#xff08;包含二、十、十六进制&#xff09;和字符 语法&#xff1a;a DB 数据个数…

“人工智能+”带来新变化

以生成式人工智能&#xff08;AIGC&#xff09;为代表的新一代人工智能技术创新加速演进&#xff0c;相关商业化应用成果也不断涌现&#xff0c;行业应用范围不断拓展&#xff0c;深度赋能实体经济&#xff0c;为行业提质增效与实现减排提供助力。 自主航运初创公司OrcaAI于6月…

g++制作C++动态库的简洁例程

g制作C动态库的简洁例程 code review! 文章目录 g\制作C动态库的简洁例程1. 创建 C 动态库1.1 动态库源文件1.2 编译动态库 2. 使用动态库2.1 命令行编译链接然后运行2.2 使用 CMake 编译链接然后运行 3.附加笔记&#xff1a;关于运行时是否能找到libmylib.so的问题汇总3.1.g -…

STM32项目分享:智能窗帘系统

目录 一、前言 二、项目简介 1.功能详解 2.主要器件 三、原理图设计 四、PCB硬件设计 1.PCB图 2.PCB板打样焊接图 五、程序设计 六、实验效果 七、资料内容 项目分享 一、前言 项目成品图片&#xff1a; 哔哩哔哩视频链接&#xff1a; https://www.bilibili.c…

浅析缓存技术

缓存技术的原理 缓存技术通过在内存中存储数据副本来加速数据访问。当应用程序需要数据时&#xff0c;首先检查缓存是否存在数据副本&#xff0c;如果有则直接返回&#xff0c;否则再从原始数据源获取。这种机制大大减少了访问时间&#xff0c;提升了系统的响应速度和整体性能。…

谷歌手机刷机教学

注意&#xff1a;手机已经解开了oem锁和bl 1、adb基础命令 连接设备adb devices&#xff1a;列出当前连接的所有设备。 adb connect <设备IP>&#xff1a;通过IP地址连接设备&#xff08;用于无线连接&#xff09;。 设备信息adb shell getprop&#xff1a;获取设备的所…

Linux使用——查看发行版本、内核、shell类型等基本命令

先做快照 虚拟机中编辑网络 关机 普通账户和管理员账户 互相对照 localhost相当于IP 参数: 短格式:以减号(-)开头&#xff0c;参数字母 长格式:以2个减号(--)后跟上完整的参数单词 当前发行版本 [rootserver ~]# cat /etc/redhat-release Red Hat Enterprise Linux release 9.…

Langchain实战:构建高效的知识问答系统

引言 知识问答系统&#xff08;KQA&#xff09;是自然语言处理领域的核心技术之一&#xff0c;它能够帮助用户从大量数据中快速准确地检索到所需信息。知识问答系统成为了帮助个人和企业快速获取、筛选和处理信息的重要工具。它们在很多领域都发挥着重要作用&#xff0c;例如在…