作业信息

这个作业属于哪个课程 <班级的链接>(如2022-2023-1-计算机基础与程序设计
这个作业要求在哪里 <作业要求的链接>(如2022-2023-1计算机基础与程序设计第十二周作业)
这个作业的目标 <写上具体方面>
作业正文 … 本博客链接

学习目标

学习资源
·教材
·阅读 「反作弊」:任何时候发现同学们有抄袭作业,抄袭代码的情况,即时课程总成绩清零
学习任务
·加入云班课,参考本周学习资源

自学教材

《·C语言程序设计》第11章并完成云班课测试
·参考上面的学习总结模板,把学习过程通过博客(随笔)发表,博客标题“学年 学号 《计算机基础与程序设计》第十二周学习总结”,博客(随笔)要通过作业提交,截至时间本周日 23:59。本周作业还要完成下面任务:

我对以往的C语言程序设计的一些基础知识进行了梳理总结

用于单分支控制的条件语句

if  ( 表达式 )
	语句;
or
if  ( 表达式 )
{
	语句1;
	语句2;
}


 
双分支(Double Selection)
 
if(条件)
{
   语句;
}
else
{
  语句;
} 
条件运算符和条件表达式
表达式1 ? 表达式2 : 表达式3




用于多分支控制的条件语句
 

if()
{
语句;
}
else if()
{

}
else if()
{

}
else
{

}
用于多路选择的switch语句
switch()
{
case value 1:
              语句1;
              break;
case value 2:
              语句2;
              break;
case value 3:
              语句3;
              break;
........
default:
              语句n;
              break;


}
 

表达式必须是int或char!;
value必须是常量;

循环控制结构

for (initial value ;   condition;   update counter) 
		statement;
Or
for (initial value ;   condition;   update counter)
{
	  statement;
	  statement;
}

其中for(起始条件;结束条件;变量增值)

当型循环
while (condition) 
	statement;
    Or
	while (condition)
     {
		statement;
		statement;
	}
 
直到型循环
do{ 
	 statement;
	 statement;
} while (condition) ;
statement;
 

 如果循环次数已知,计数控制的循环
 用for
 如果循环次数未知,条件控制的循环
 用while
 如果循环体至少要执行一次
 用do-while
 这只是“一般”原则,不是“原则”

递归函数

unsigned long Fact(unsigned int n) 
{ 
	if (n == 0 || n == 1) 
		return 1;
	else 
		return n * Fact(n-1); 
}

求斐波那契数列
递归

long Fib(int n)
{
	long f;
	if (n == 0) f = 0;
	else if (n == 1) f = 1;
	else f = Fib(n-1) + Fib(n-2);
	return f;

复杂类型说明(指针)

int p; //这是一个普通的整型变量
int *p; //首先从P 处开始,先与*结合,所以说明P 是一个指针,然后再与int 结合,说明指针所指向的内容的类型为int 型.所以P是一个返回整型数据的指针
int p[3]; //首先从P 处开始,先与[]结合,说明P 是一个数组,然后与int 结合,说明数组里的元素是整型的,所以P 是一个由整型数据组成的数组
int *p[3]; //首先从P 处开始,先与[]结合,因为其优先级比*高,所以P 是一个数组,然后再与*结合,说明数组里的元素是指针类型,然后再与int 结合,说明指针所指向的内容的类型是整型的,所以P 是一个由返回整型数据的指针所组成的数组
int (*p)[3]; //首先从P 处开始,先与*结合,说明P 是一个指针然后再与[]结合(与"()"这步可以忽略,只是为了改变优先级),说明指针所指向的内容是一个数组,然后再与int 结合,说明数组里的元素是整型的.所以P 是一个指向由整型数据组成的数组的指针
int **p; //首先从P 开始,先与*结合,说是P 是一个指针,然后再与*结合,说明指针所指向的元素是指针,然后再与int 结合,说明该指针所指向的元素是整型数据.由于二级指针以及更高级的指针极少用在复杂的类型中,所以后面更复杂的类型我们就不考虑多级指针了,最多只考虑一级指针.
int p(int); //从P 处起,先与()结合,说明P 是一个函数,然后进入()里分析,说明该函数有一个整型变量的参数,然后再与外面的int 结合,说明函数的返回值是一个整型数据
Int (*p)(int); //从P 处开始,先与指针结合,说明P 是一个指针,然后与()结合,说明指针指向的是一个函数,然后再与()里的int 结合,说明函数有一个int 型的参数,再与最外层的int 结合,说明函数的返回类型是整型,所以P 是一个指向有一个整型参数且返回类型为整型的函数的指针
int *(*p(int))[3]; //可以先跳过,不看这个类型,过于复杂从P 开始,先与()结合,说明P 是一个函数,然后进入()里面,与int 结合,说明函数有一个整型变量参数,然后再与外面的*结合,说明函数返回的是一个指针,,然后到最外面一层,先与[]结合,说明返回的指针指向的是一个数组,然后再与*结合,说明数组里的元素是指针,然后再与int 结合,说明指针指向的内容是整型数据.所以P 是一个参数为一个整数据且返回一个指向由整型指针变量组成的数组的指针变量的函数.

教材学习内容总结

11.1指针与一维数组的关系
C语言中的数组名有特殊意义,它代表存放数组元素的连续存储空间的首地址,即指向第一个数组元素的指针常量。
因此,数组元素既可用下标法,也可用指针法来应用。

11.2指针与二维数组的关系

11.3指针数组及其应用
11.4动态数组
11.5扩充内容及其应用
11.5.1常见的内存错误及其对策
11.5.2缓冲区溢出攻击

原文地址:http://www.cnblogs.com/20031004wzy/p/16900894.html

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,请务用于商业用途! 3. 如果你也有好源码或者教程,可以到用户中心发布,分享有积分奖励和额外收入! 4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 5. 如有链接无法下载、失效或广告,请联系管理员处理! 6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 7. 如遇到加密压缩包,默认解压密码为"gltf",如遇到无法解压的请联系管理员! 8. 因为资源和程序源码均为可复制品,所以不支持任何理由的退款兑现,请斟酌后支付下载 声明:如果标题没有注明"已测试"或者"测试可用"等字样的资源源码均未经过站长测试.特别注意没有标注的源码不保证任何可用性