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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

C语言学习大纲郝斌讲解.docx

1、C语言学习大纲郝斌讲解C语言概述:1、为什么学习C语言1). C的起源和发展2).C的特点优点代码量小 速度快 功能强大缺点危险性高开发周期长可移植性不强3).c的应用领域 主要是系统领域4).c的重要性2、怎样学习C语言3、学习的目标了解程序语言及发展历史熟练掌握c语言的语法规则掌握简单的算法理解面向过程的思想,这非常有助于将来对面向对象思想的学习能看懂程序会调试程序掌握将大问题转化为一系列小问题来求解的思想为学习c+、数据结构、c#、java打下良好的基础4、常见的学习问题1、学习java为什么建议先学习C语言2、没学过计算机专业的课程能够学懂C语言3、英语和数学不好能学好C吗 32个关键

2、词:(有系统定义,不能重做其他定义)auto break case char const continue default do double else enum extern float for goto if int long register returnshort signed sizeof static structswitch typedef unsigned unsigned union void volatile while 5、课程规划c语言简介 第一讲、基本编程知识 第二讲、数据类型第三讲、运算符和表达式第四讲、流程控制(所有语言都一样的)第五讲、函数(体现出面向过程和面向

3、对象的区别)第六讲、数组第七讲、指针(c语言的灵魂)第八讲、变量的作用域和存储方式第九讲、扩展数据类型第十讲、专题:字符串的处理进制转换补码动态内存分配(java、数据结构必学)综合应用:链表的使用6、举例子:一元二次方程# include # include int main (void)/把三个系数保存到计算机中int a=1; /=不表示相等,表示赋值int b=2;int c=3;double delta; /delta存放的是b*b-4*a*cdouble x1; /存放一元二次方程的其中一个解double x2; /存放一元二次方程的其中一个解delta= b*b - 4*a*c;

4、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);x1=x2; /右边赋给左边printf(该一元二次方程有一个唯一解,x1 = x2=%fn,x1);elseprintf(无解n);Helloword程序举例# include int main(void)printf(欢迎大家学习C语言!);return 0;C语言编写的病毒举例:1、龌龊的程序:/*龌龊的程序!

5、/*# include # include # include int main (void)int c;int i;int j;Nihao:printf(1:死机n);printf(2:机房爆炸n);printf(请选择:);scanf(%d,&c);If (c =1)System(shutdown -s -t 60)else if (2 = c)printf(你太坏了 我要惩罚你!n);for (j=0;j10;+j)System(start); elseprintf(你敲错了,请重新输入!n)goto nihao;return 0;2、内存泄露(占满内存)程序导致死机实例# includ

6、e # include int main(void)while (1) int *p = (int*)malloc(1000);return 0;C语言编程预备知识1、cpu 内存条 硬盘 显卡 主板 显示器 之间的关系2、Helloworld程序如何运行起来的3、什么是数据类型基本类型数据整数整型 int 字节 短整型 short int 字节长整型 long int 字节 浮点数【实数】单精度浮点数 float 字节双精度浮点数 double 字节字符char 字节复合类型数据结构体枚举共用体(已淘汰)4、什么是变量变量的本质是内存中一段存储空间5、cpu内存条 vc+6.0 操作系统 之

7、间的关系6、变量为什么必须初始化所谓初始化就是赋值的意思7、如何定义变量数据类型 变量名 = 要赋的值;等价于数据类型 变量名;变量名 = 要赋的值;举例子:int i = 3 ; 等价于 int i ; i = 3;int i, j ; 等价于 int i ; int j;int i, j = 3 ; 等价于 int i ; int j ; j = 3 ;int i = 3, j = 5 ; 等价于 int i , j ; i = 5 ; j = 5;int i , j ; i = j = 5 ;等价于 int i , j ; i = 5; j = 5; 8、什么是进制十进制就是逢十进一二进

8、制就是逢二进一生活中用到进制的例子:一周七天: 七进制一年十二个月: 十二进制一小时六十分钟: 六十进制电脑中的数据: 二进制进制转化:什么叫进制进制就是逢几进一我们说的N进制实际就是指逢N进一我们的计算机只识别二进制人类最习惯使用的是十进制为了实际需要 我们又建立了八进制和十六进制C语言规定八进制前要加0(注意是零不是字母o),十六进制前要加0X或0x,十进制前什么都不加!在汇编中:在数字后加字母B表示二进制数,加字母O表示八进制数,加字母D表示十进制,加字母H表示十六进制。例:1011B为二进制数1011,也记为(1011)21357O为八进制数1357,也记为(1357)82049D为十

9、进制数2049,也记为(2049)103FB9H为十六进制数3FB9,也记为(3FB9)16什么叫n进制十进制十个基数,逢10进一基数:0 1 2 3 4 5 6 7 8 9二进制二个基数 逢二进一基数: 0 1八进制8个基数 逢8进一基数: 0 1 2 3 4 5 6 7十六进制16个基数 逢16进一基数: 0 1 2 3 4 5 6 7 8 9 a b c d e f 或0 1 2 3 4 5 6 7 8 9 A B C D E F十进制(D)二进制(B)八进制(O)十六进制(0x)00001常用计数制对照表234567891011121314159、常量在c语言中如何表示的 整数十进制:

10、 传统的写法十六进制: 前面加0x或0X,是数字0加x八进制: 前面加数字0浮点数:传统写法float x = 3.2;/传统科学计数法float x = 3.2e3;/x的值是3200float x = 123.45e-2; /x的值是1.2345字符单个字符用单引号括起来A表示字符AAB是错误的AB是正确的字符串用双引号括起来A正确,因为A代表了 A 0 的组合10、常量以什么样的二进制代码存储在计算机中整数是以补码的形式转化为二进制代码存储在计算机中的实数是以IEEE754标准转化为二进制代码储存在计算机中的具体可参见末尾的 穿插在课堂中的零散知识笔记字符的本质实际也是与整数的存储方式相

11、同11、代码规范化代码的可读性更高【容易让别人和自己看懂】是程序更不容易出错林锐高质量C/C+编程 代码要成对的敲12、什么是字节字节就是存储数据的单位,并且是硬件所能访问的最小单位1字节 = 8位1K = 1024字节1M = 1024 K1G = 1024 M 买硬盘时的换算是以1000为单位的13、不同类型的数据之间相互赋值的问题暂不考虑int i = 45;long j = 102345;i= j;printf (%d %dn, i, j);float x = 6.6;double y = 8.8;printf(%f %lfn, x, y);14、什么是ASCIIASCII不是一个值,

12、而是一种规定,ASCII规定了不同的字符是使用哪个整数值去表示它规定了A - 65B - 66a - 97b - 9815、字符的存储【字符本质上与整数的存储方式相同】基本的输入和输出函数的用法printf ()-(重点讲)将变量的内容输出到显示器上四种用法1.printf (字符串n)2.printf (输出控制符,输出参数);3.printf (输出字符1 输出字符2 。, 输出参数1, 输出参数2, 。);输出控制符和参数的个数必须一一对应4.printf(输出控制符 非输出控制符, 输出参数);输出控制符包含如下%d - int (十进制)%ld - long int%c - char

13、%f - float%lf - double%x(或者%X或者%#X) - int 或 long int 或 short int%o - 同上%s - 字符串为什么需要输出控制符1. 01组成的代码可以表示数据也可以表示指令2. 如果01组成的代码表示的是数据的话,那么同样的01代码组合以不同的输出格式输出就会有不同的输出结果scanf () -Java中已经没有了两种用法:用法一: scanf (输入控制符, 输入参数);功能: 将从键盘输入的字符转化为输入控制符所规定格式的数据,然后存入已输入参数的值为地址的变量中。用法二: scanf(非输入控制符 输入控制符, 输入参数);功能: 将从

14、键盘输入的字符转化为输入控制符所规定格式的数据,然后存入以输入参数的值为地址的变量中非输入控制符必须原样输入如何使用scanf编写出高质量代码1. 使用scanf之前最好先使用printf提示用户以什么样的方式来输入2. Scanf中尽量不要使用非输入控制符,尤其是不要用n3. 应该编写代码对用户的非法输入做适当的处理【非重点】while (ch=getchar() != n) continue;运算符算术运算符+ - * /(除) %(取余数)除法的运算结果和运算对象的数据类型有关,两个数都是int,则商就是int,若商有小数,则截取小数部分;被除数和除数中只要有一个或两个都是浮点型数据,则

15、商也是浮点型,不截取小数部分。如: 16/5 = 3 16/5.0 = 3.20000 -13/4 = -4 -13/-3 = 4 3/5 = 0 5/3 = 1最经典的例题就是求s = 1 + 1/2 + 1/3 + 1/4 + 1/5.+ 1/100的值。取余的运算对象必须是整数,结果是整除后的余数,其余数的符号与被除数相等。如: 13%3 = 1 13%-3 = 1 -13%3 = -1 -13%23 = -13 3%5 = 3 关系运算符 = 关系 逻辑 赋值 附录一些琐碎的运算符知识自增 自减 三目运算符 逗号表达式流程控制 (学习c语言的第一个重点) 1. 什么是流程控制程序代码执

16、行的顺序2. 流程控制的分类顺序选择定义某些代码可执行,也可能不执行,有选择的执行某些代码分类if1. if最简单的用法格式:if (表达式)语句功能:如果表达式为真,执行语句如果表达式为假,语句不执行2. if的范围问题(重点)1.if (表达式)语句A;语句B;解释:if默认只能控制语句A的执行或不执行 if无法控制语句B的执行或不执行或者讲: 语句B一定会执行2. If (表达式)语句A;语句B;此时if可以控制语句A和语句B由此可见:if默认只能控制一个语句的执行或不执 行,如果想控制多个语句的执行或不执 行就必须把这些语句用括起来。3. if.else.的用法4. if.else i

17、f.else.的用法格式:if (表达式1)A;else if (表达式2)B;if (表达式3)C;elseD;5. C语言对真假的处理非零是真零就是假真用一表示假用零表示6. if举例-求分数的等级7. if的常见问题解析1. 空语句的问题if (3 2);等价于if (3 2); /这是一个空语句2. if (表达式1)A;elseB;是正确的if (表达式1);A;elseB;是错误的 3. if (表达式1) A; else if (表达式2) B; if (表达式3) C; else D;即便表达式1和2都成立,也只会执行A语句4. if (表达式1) A;else if (表达式

18、2) B;if (表达式3) C;这样些语法不会错,但逻辑上有漏洞、 5. if (表达式1) A;else if (表达式2) B;if (表达式3) C;else (表达式4) /7行 D;这样写是不对的,正确的写法是: 要么去掉7行的(表达式4) 要么在7行的else后面加if if (表达式1) A;else if (表达式2) B;if (表达式3) C;else (表达式4); D;这样写语法不会错,但逻辑上是错误的else (表达式4); D; 等价于 else (表达式4); D;对任意三个数字进行排序:如果ab则a与c比较 ac 则输出a ac 则输出b bc 则输出c穿插在

19、课堂中的零散知识笔记:如何看懂一个程序,分三步:1. 流程2. 每个语句的功能3. 试 数如何学习一些需要算法的程序【如何掌握一个程序】1. 尝试自己去编程解决它但要意识到大部分人都是自己无法解决的,如果解决不了,这时不要气馁如果十五分钟还想不出来,此时我建议您就可以看答案了2. 如果解决不了,就看答案关键是把答案看懂,这个要花很大的精力,也是我们学习的重点看懂一个程序要分三步:流程、每个语句的功能、试数3. 看懂之后尝试自己去修改程序,并且知道修改之后程序的不同输出结果的含义不建议看懂程序之后就立即自己敲程序4. 照着答案去敲5. 调试错误6. 不看答案,自己独立把答案敲出来7. 如果程序实

20、在无法彻底理解,就把它背会,无法彻底理解的程序很少很少几乎没有 强制类型转换 格式: (数据类型)(表达式) 功能: 把表达式的值强制转换为前面所执行的数据 类型 例子: (int)(4.5+2.2) 最终值是 6 (float)(5) 最终值是 5.0000000 浮点数的存错所带来的问题 float和 double都不能保证可以把所有实数都准确的 保存在计算机中 例子: float i = 99.9; printf(%fn, i); 最终结果在VC+6.0中的输出的结果是: 99.900002 因为浮点数无法准确存储,所以就衍生出来两个编程 问题 举例: 有一个浮点型变量x,如何判断x的值

21、是否是零 if (|x-0.0000001| m=121 sum=0*10+121%10=1 m=m/10=12;m=12成立 sum=1*10+12%10=12 m=12/10=1m=1成立 sum=12*10+1%10=121 m=1/10=0m=0不成立sum=val4. 什么时候使用while,什么时候使用for没法说,用多了自然而然就知道了do.while格式:do.while(表达式);do.while.并不等价于for,当然也不等价于while主要用于人机交互一元二次方程举例break和continuebreak(很重要)break如果用于循环是用来终止循环break如果用于sw

22、itch,则是用于终止switchbreak不能直接用于if,除了if属于循环内部的一个子句例子: for (i=0;i 2) break; /break虽然是if内的语句,但break终 止的却是外部的for循环 printf (嘿嘿!n); /永远不会输出 在多层循环中,break只能终止距离它最近的 那个循环 for (i=0; i3; +i) for (j=1; j4;+j) break; /break只能终止距离它最近的循环 printf (同志们好!n); 在多层switch嵌套中,break只能终止距离它 最近的switch例子:int x=1, y=0, a=0, b=0; switch (x) /第一个switch case 1: switch (y) /第二个switch case 0: a+; break; /终止的是第 二个switch case 1: b+; break; b = 100; break; /终止的是第一个 switch case 2: a+;

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

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