ImageVerifierCode 换一换
格式:DOCX , 页数:139 ,大小:2.62MB ,
资源ID:18161792      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/18161792.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(学习C语言详细笔记完整版文档格式.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

学习C语言详细笔记完整版文档格式.docx

1、现在市场上的语言分三块:C/c+:单纯的学习c是什么都做不了的。JavaC#可移植性不强:这是针对java来说的,因为java的可移植性太强了,所以就感觉说c的可移植性不强。3)C语言的应用领域:驱动一般是用c和汇编来写的。数据库一般是用c和c+来写的4)C语言的重要性: 虽然应用场合相对较窄,但贴近系统内核,较底层。病毒最基本的是要感染系统,数据结构,c,c+这三门语言是必须要学习的。牛人牛语:梁肇新:编写的超级解霸 播放器软件,被暴风影音收购。编写的书编程箴言二、怎样学习C语言(ppt)1、要将编程当成一项事业来经营,而不是糊口的工具。2、途径:多思考,多上机。 目标:不能光看,光听,而要

2、排错,能看懂程序,能调试程序,自学能力要很强。3、在犯错误中成长。参考资料:王爽写的c+也很不错三、学习的目标(ppt)掌握简单的算法-解决问题的方法和步骤。熟悉语法规则。能看懂程序并调试程序。四、常见问题答疑(ppt)C语言的关键字:C语言程序的格式:# include math.hint main(void) /把三个系数保存在计算机中,定义三个变量。 int a=1; /=不表示相等,表示赋值 int b=2; int c=3; float delta; /delta存放的是b*b-4*a*c /float改double float x1; /存放一元二次方程的其中一个解float x2

3、; delta=b*b-4*a*c; if(delta0) x1=(-b+sqrt(delta)/(2*a);x2=(-b- sqrt(delta)/(2*a); /两个解printf(“该一元二次方程有两个解,x1=%f,x2=%fn”,x1,x2);else if(delta=0) x1=(-b)/(2*a); /唯一解x2=x1; /右边值赋给左边printf(“该一元二次方程有一个唯一解,x1=x2=%fn”,x1);else printf(“无解n”); /无解return 0;一定要养成良好的习惯:代码规范,边写边保存 ,括号成对出现,应用空格。VC6.0软件操作:新建 保存 关闭

4、(关闭空间).cpp是原始文件,可单独拷贝到其它电脑。第二讲:(14-25)C语言编程必备知识1、Cpu,内存条,硬盘,显卡,主板,显示器之间关系。Cpu不能直接处理硬盘上的数据,必须要先调入内存。2、Hello word程序是如何运行起来的。3、什么是数据类型数据类型-数据的分类,对编程而言,首要考虑问题是数据的输入和存储。可以分为A:基本数据类型:(整数、浮点数、字符)(1)整型整型 int -4字节 一字节byte = 8 位bit短整型 short int -2字节长整型 long int -8字节(2)浮点型【实数】 单精度浮点数float:存储范围小 -4字节 双精度浮点数doub

5、le:存储范围大 -8 字节Float 和 Double 都不能保证将小数完全准确保存。(3)字符char:c语言中是没有字符串string -1 字节(区别于JAVA、C#中有string且C#中 char为2字节)B:复合类型:就是把基本类型拼凑在一起结构体枚举 - 实用共用体基本淘汰4、什么是变量 变量的本质是内存中一段存储空间。int i; i=5; i 是变量,程序向系统申请了一个内存单元,在程序运行中,i的值可以改变,但程序结束后,其所占的空间不是释放,而是被系统收回权限。5、Cpu,内存条,vc+6.0,操作系统之间的关系。6、变量为什么必须的初始化(即赋值)软件运行与内存关系(

6、垃圾数据-9868598658)内存是在操作系统的统一管理下使用的!(1)软件在运行前需要向操作系统申请存储空间,在内存空间足够空闲时,操作系统将分配一段内存空间并将该外存中软件拷贝一份存入该内存空间中,并启动该软件运行。(2)在软件运行期间,该软件所占内存空间不再分配给其他软件。(3)当该软件运行完毕后,操作系统将回收该内存空间(注意:操作系统并不清空该内存空间遗留下来的数据),以便再次分配给其他软件使用。操作系统一门课中系统分配表中会讲到,用1标记表示内在是被占用的,用0标记表示是空闲的。综上所述,一个软件所分配到的空间中极可能存在着以前其他软件使用过后的残留数据,这些数据被称之为垃圾数据

7、,所以通常情况下我们为一个变量,为一个数组,分配好存储空间之前都要对该内存空间初始化。7、如何定义变量数据类型 变量名称 = 赋予的值;等价于 数据类型 变量名; 变量名 = 要赋予的值;举例子:int i = 3; 等价于 int I ; i = 3;int i, j; 等价于 int i; int j;int i, j=3 等价于 int i; j = 3;int i =3, j = 5;等价于 int i; int j;j = 5;i = j = 5; 等价于 int i , j; i = 5; j = 5;8、什么是进制 (逢几进一)看ppt我们规定八进制前面加0(零),十六进制前面加

8、0x。常用计数制对照表:Printf的基本用法:9、常量在c中是如何表示的单个字符使用单引号括起来,多个字符串使用双引号括起来(指针、数组)。A表示字符AAB 错误 “AB”正确(字符串要用双引号括起来)“A”正确,因为“A”代表了A 0的组合在c中,默认是double类型的。在后面加F表示当做float来处理,否则会有警告提示 -丢失部分字节。10、常量以什么样的二进制代码存储在计算机中?编码:整数是以补码的形式转换为二进制代码存储在计算机浮点数是以ieee754标准转换为二进制代码存储字符本质实际是与整数的存储方式相同,ASCII码标准。第三讲:(26-46)一、代码规范化 可以参考林锐高

9、质量c/c+编程代码的规范化非常的重要,是学习一门编程语言的基础,代码可以允许错误,但不能 不规范。例如:成对敲括号 ()加空格于 运算符和数字之间 i = 1 + 2;加缩进 分清上下级地位。换行-进行功能区域分隔 or 括号单独成一行。代码规范化的好处1:整齐,别人和自己都容易看懂。2:代码规范了,代码不容易出错。3:一般的程序可以分为三块: a: 定义变量 b:对变量进行操作 c: 输出值二、什么是字节存储数据的单位,并且是硬件所能访问的最小单位。内存中存储的最小单位是位bit(0或1),但是硬件控制的时候不能精确到位,只能精确到字节(8位),是通过地址总线来控制的,而精确到位是通过软件

10、来控制的,叫做位运算符来精确到位的。1字节 = 8 位 1K = 1024 字节 1M = 1024 K 1G =1024 M 1T = 1024 G 2G的内存条的总空间:2 *1024 * 1024 *1024 * 8 =4*1032三、不同类型数据之间相互赋值的问题不同数据类型之间最好不要相互转换。如果需要明白这个知识点,那么需要明白补码。四、什么是ASCII码在上图中注释的最后一样是重复定义了ch的值,是错误的,而下面的ch = c是指把c赋值给ch,是正确的。以char定义变量的时候,只能使用单引号括起一个字符才是正确的。上图中输出的值是98(将字符以整数%d的形式输出)Ascll码

11、规定了ch是以哪个值去保存。Ascll码不是一个值,而是一种规定,规定了不同的字符是以哪个整数值去表示。它规定了: A - 65 B - 66 a - 97 b - 98 0 - 48五、字符的存储字符本质上与整数的存储方式相同基本的输入和输出函数的用法:Printf() -将变量的内容输出到显示器上。 四种用法:输什么是输出控制符,什么是非输出控制符输出控制符包含如下:Printf为什么需要输出控制符:01组成的代码可以表示数据也可以表示指令。必须要有输出控制符告诉他怎么去解读。如果01组成的代码表示的是数据的话,那么同样的01代码组合以不同的输出格式输出就会有不同的输出结果,所以必须要有输

12、出控制符。在上图中,int x =47,如果前面加0(零)048表示的是八进制,如果前面加0x(零x)0X47则表示的是十六进制,而在输出的时候,则是o(字母o)表示八进制,ox(字母o,x)表示十六进制。非输出控制符:非输出控制符在输出的时候会原样输出。Scanf()-通过键盘将数据输入到变量中有两种用法:示例:非输入控制符:在输入的时候也会原样输入。但是强烈建议:在使用scanf的时候,不使用非输入控制符。给多个变量赋值: int i , j; scanf(“%d %d”, &i, &j); printf(“i = %d, j = %dn”, i, j); return 0; 需要记住,非

13、控制符需要原样输入。如何使用scanf编写出高质量代码运算符: (1)算术运算符: 加(+) 减() 乘(*) 除(/) 取余(%)(2)关系运算符: = 关系逻辑赋值。取余的结果的正负只和被除数有关。第四讲 (47-96)流程控制(第一个重点):1、什么是流程控制程序代码执行的顺序。2、流程控制的分类 顺序执行 选择执行定义:某些代码可能执行,也可能不执行,有选择的执行某些代码。 循环执行分类:if、switchif最简单的用法:如果想控制多个语句的执行或者不执行,那么需要使用 括起来。3. ifelse的用法:4、ifelse ifelse的用法:(格式)C错误的ifelse ifelse

14、语句:在上图中,当执行到哈哈那句时,下面的else将会被算作另外一个语句来执行,而在我们的c语言中,没有以else开头的语句。所以会出错。5、C语言对真假的处理非零是真 (真用1表示)零就是假 (假用0表示)6、if 实例(举例-求分数的等级):(1)变量的替换:(互换两个数字)(2)对任意三个数字进行排序:(3)C语言常见误区:素数:只能被1和自己整除的数,如1,5,9等。回文数:正着写和倒着写一样的数。如1221,121,等。编程实现求一个十进制数字的二进制形式。求一个数字的每位是奇数的数字取出来组合形成的新数字。求一个数字倒过来的数字。算法:解题的方法和步骤。如何看懂一个程序,分三步:1

15、、流程:也就是程序执行的顺序;2、每个语句的功能;3、试数:找一个数带入程序验证。如何学习一些需要算法的程序(如何掌握一个程序):1、尝试自己编程解决它,但要意识到大部分人都是自己无法解决的,这时不要气馁。如果十五分钟还想不出来,此时我建议您就可以看答案了。2、如果解决不了,看答案。3、关键是把答案看懂,这个要花很大的精力,也是我们学习的重点。看懂一个程序要分三步:流程、每个语句的功能、试数。4、看懂之后尝试自己修改程序,并且知道修改之后程序的不同输出结果的含义。不建议看懂程序之后就立即自己敲程序。5、照着答案去敲6、调试错误7、自己不看答案,自己独立把答案敲出来。8、如果程序实在是彻底无法理

16、解,就把他背会。(很少有这种程序)7、if常见的问题解析:1、空语句的问题: if ( 3 2 ) ; 等价于 2 ) ; / 这是一个空语句在上图中,最终的结果会是AAAA,BBBB,程序也不会报错,为什么呢,因为在程序执行的时候,会在;哪里认为是一个空语句。也就是说,如果if成立,那么执行空语句。2、If常见错误解析(重点)上面这个程序是错误的,为什么呢,在该程序中,总的有4个语句,而在以else开头的那个语句中是有错误的,因为在c语言中是没有以else开头的这种语法。3、If常见错误解析if (表达式1)A;else if (表达式2)B;else if (表达式3)C;D;即便表达式1

17、和2都成立,也只会执行A语句。程序测试:在上面这个程序中,最终的值是AAAA,虽说后面的31也满足条件,但是当32满足条件后,该if语句就会终止,后面的语句是不会在执行的。4、If常见错误解析(用成绩等级程序验证)5、If常见错误解析(用成绩等级程序验证) 这样写是不对的,正确的写法是: 要么去掉第7行的(表达式4) 要么在第7行的else后面加if6、If常见错误解析(if常见问题解析_5.cpp) 循环的定义、分类。某些代码会被重复执行。for(重点)while dowhile (1) 格式: for ( 1 ; 2; 3) 语句A;(2)执行的流程(重点) 单个for循环的使用 多个fo

18、r循环的嵌套使用(具体附后)(3)范围问题: (4)举例: 1+2+3+100 1+1/2+1/3+1/100在上图中,先执行1,在执行2,2如果成立,标志着循环成立,那么在执行4,最后在执行3,3执行完后代表一次循环完成,然后在执行2.以此类推。1永远只执行一次。+i 等价于 i+1例1:求1-10的所有奇数的和: for所控制的语句:在上图中,for默认只能控制一个语句,但是如果要控制多个语句时候,那么需要使用 把语句括起来。例2:求1-12之间的所有能被3整除的数字之和:例3:求1+1/2+1/3.1/100的和。在上图中,重点是强制数据类型转换也就是(float) (i)那句:如果把p

19、rint那句换为下面这句会怎么样呢:也是错的,为什么呢,因为i是整型,1也是整型,所以不管你怎么转换也是整型啊,如果想要这样写的话,那么我们需要把1改成1.0也可以的。也就是: 更简单的写法是:sum = sum + 1.0/i;试数详细步骤举例:浮点数存取的问题: 浮点数的存错所带来的问题 float和double都不能保证可以把所有的实数都准确的保存在计算机中。 例子: float I = 99.9; prinf(“%fn”, i); 最终在Vc+6.0中的输出结果是:99.900002 因为浮点数无法准确存储,所以就衍生出来两个编程问题: 有一个浮点型变量x,如何判断x的值是否是零 if

20、 (|x-0.000001| = 0.000001) 是零 else 不是零 为什么循环中更新的变量不能定义成浮点型for循环和if的嵌套使用四个习题练习:求1-100之间所有奇数的和求1-100之间的奇数的个数求1-100之间奇数的平均值求1-100之间的奇数之和,在求1-100之间的偶数之和。例 求1-100之间所有奇数的和: int i; int sum = 0; for (i=1; i101; +i) if (i%2 = 1) sum += i; / sum = sum + i; printf(sum = %dn, sum);例 求1-100之间的奇数的个数: int cnt = 0;

21、 /个数一般用cnt表示 +cnt;cnt = %dn, cnt);例 求1-100之间奇数的平均值: float avg; /average 的缩写 avg = 1.0*sum / cnt; /1.0默认是double类型avg = %fn, avg);例 求1-100之间的奇数之和,在求1-100之间的偶数之和: int sum1 = 0; /奇数和 int sum2 = 0; /偶数和 sum1 += i; else sum2 += i;奇数和 = %dn, sum1);偶数和 = %dn, sum2);多个for循环的嵌套使用:整体是两个语句。上图中,先执行1,在执行2,如果2成立,执

22、行4,在执行5,如果5成立执行A,在执行6,在执行5,如果5不成立,意味着里面的循环结束,然后执行3,在执行2,如果2成立又执行4,在执行5,如果5成立在执行6,在执行5,如果5不成立,在执行3,在执行2,如果2不成立,意味着本次循环结束,在执行B,在上图中,需要注意的是,如果2成立的话,那么每次4都需要执行。【复习进制的知识】进制之间的转换:1、什么叫n进制 逢n进一2、把r进制转成十进制如234为5进制,那么转换成10进制是多少?2x5x5+3x5+4的值就是转换成的10进制。234e是16进制,转换成10进制是多少?2x16x16x16+3x16x16+4x16+12的值就是转换成10进制的值。注意上面的规律。3、十进制转成r进制4、不同进制所代表的数值之间的关系(例2) 十进制的 3981 转化成 十六进制是 F8D 十进制的 3981和十六进制的 F8D所代表的本质上都是同一个数字。那么把十进制转换成r进制呢,其实很简单,就是把10进制数除以r,直到商是0的时候。然后取余数,余数倒序排列:十进制转二进制 十进制转十六进制【复习运算符的知识】复习前面的运算符知识:一些琐碎的运算符知识:1、自增或者自减举例:为什么会出现自增1、代码更精炼2、自增的速度

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1