欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    第2章 C简单程序设计.ppt

    • 资源ID:79004590       资源大小:924.50KB        全文页数:103页
    • 资源格式: PPT        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    第2章 C简单程序设计.ppt

    第二章第二章 C+C+简单程序设计简单程序设计C+语言程序设计C+语言程序设计2本章主要内容本章主要内容lC+语言概述语言概述l基本数据类型和表达式基本数据类型和表达式l数据的输入与输出数据的输入与输出l算法的基本控制结构算法的基本控制结构l自定义数据类型自定义数据类型C+语言程序设计3C+语言的产生语言的产生lC+C+是从是从C C语言发展演变而来的,首先是一个语言发展演变而来的,首先是一个更好的更好的C Cl引入了类的机制,最初的引入了类的机制,最初的C+C+被称为被称为“带类的带类的C C”l19831983年正式取名为年正式取名为C+C+l从从19891989年开始年开始C+C+语言的标准化工作语言的标准化工作l于于19941994年制定了年制定了ANSI C+ANSI C+标准草案标准草案l于于19981998年年1111月被国际标准化组织(月被国际标准化组织(ISOISO)批准)批准为国际标准,成为目前的为国际标准,成为目前的C+C+C+语言概述C+语言程序设计4C+的特点的特点l全面兼容全面兼容C C它保持了C的简洁、高效和接近汇编语言等特点对C的类型系统进行了改革和扩充C+也支持面向过程的程序设计,不是一个纯正的面向对象的语言l支持面向对象的方法支持面向对象的方法C+语言概述C+语言程序设计5C+程序实例程序实例例例2-1/2_1.cpp/2_1.cpp#include#include using namespace std;using namespace std;intint main()main()coutcout Hello!Hello!endlendl;coutcout Welcome to c+!Welcome to c+!endlendl;return 0;return 0;运行结果:运行结果:Hello!Hello!Welcome to c+Welcome to c+!C+语言概述C+语言程序设计6C+字符集字符集l大小写的英文字母:大小写的英文字母:A AZ Z,a az zl数字字符:数字字符:0 09 9l特殊字符:特殊字符:!#%&*_ _+=-/“;.,:?()C+语言概述C+语言程序设计7词法记号词法记号l关键字C+预定义的单词l标识符程序员声明的单词,它命名程序正文中的一些实体l文字在程序中直接使用符号表示的数据l操作符用于实现各种运算的符号l分隔符(),:;用于分隔各个词法记号或程序正文l空白符空格、制表符(TAB键产生的字符)、垂直制表符、换行符、回车符和注释的总称C+语言概述C+语言程序设计8标识符的构成规则标识符的构成规则l以大写字母、小写字母或下划线以大写字母、小写字母或下划线(_)开开始。始。l可以由以大写字母、小写字母、下划可以由以大写字母、小写字母、下划线线(_)或数字或数字09组成。组成。l大写字母和小写字母代表不同的标识大写字母和小写字母代表不同的标识符。符。C+语言概述C+语言程序设计9 数据类型数据类型 常量与变量常量与变量#include#include using namespace std;using namespace std;intint main()main()const const intint PRICE=30;PRICE=30;intint num,total;num,total;float v,r,h;float v,r,h;num=10;num=10;total=num*PRICE;total=num*PRICE;coutcout total total endlendl;r=2.5;r=2.5;h=3.2;h=3.2;v=3.14159*r*r*h;v=3.14159*r*r*h;coutcout v v endlendl;return 0;return 0;常量变量变量先声明后使用符号常量基本数据类型和表达式C+语言程序设计10#include#include using namespace std;using namespace std;intint main()main()const const intint PRICE=30;PRICE=30;intint num,total;num,total;float v,r,h;float v,r,h;num=10;num=10;total=num*PRICE;total=num*PRICE;coutcout total total endlendl;r=2.5;r=2.5;h=3.2;h=3.2;v=3.14159*r*r*h;v=3.14159*r*r*h;coutcout v v endlendl;return 0;return 0;数据类型数据类型 整型数据整型数据shortunsigned short 2字节intunsigned int 4字节longunsigned long 4字节整型变量声明基本数据类型和表达式整型变量整型常量C+语言程序设计11数据类型数据类型 整型数据及取值范围整型数据及取值范围类型类型说明符说明符 位数位数数值范围数值范围短整short16-3276832767基本 int32 -231(231-1)长整long32-231(231-1)无符号unsigned short16065535 unsigned int320(232-1)unsigned long320(232-1)基本数据类型和表达式C+语言程序设计12#include#include using namespace std;using namespace std;intint main()main()const const intint PRICE=30;PRICE=30;intint num,total;num,total;float v,r,h;float v,r,h;num=10;num=10;total=num*PRICE;total=num*PRICE;coutcout total total endlendl;r=2.5;r=2.5;h=3.2;h=3.2;v=3.14159*r*r*h;v=3.14159*r*r*h;coutcout v v endlendl;return 0;return 0;数据类型数据类型 实型数据实型数据实型常量float 4float 4字节字节 3.41038 7位有效数字double 8double 8字节字节 1.710308 15位有效数字long double long double 8 8字节字节 1.710308 15位有效数字实型变量默认为double型后缀 F(或 f)为 float型后缀 L(或 l)为 long double型基本数据类型和表达式C+语言程序设计13 数据类型数据类型 字符型数据(一)字符型数据(一)l字符常量字符常量单引号括起来的一个字符,如:a,D,?,$l字符变量字符变量用来存放字符常量例:char c1,c2;c1=a;c2=A;l字符数据在内存中的存储形式字符数据在内存中的存储形式以ASCII码存储,占1字节,用7个二进制位基本数据类型和表达式C+语言程序设计14l字符数据的使用方法字符数据的使用方法字符数据和整型数据之间可以运算。字符数据与整型数据可以互相赋值。l字符串常量字符串常量例:CHINA a a所以:char c;c=a;C H I N A 0a 0aPage 14 数据类型数据类型 字符型数据(二)字符型数据(二)基本数据类型和表达式C+语言程序设计15 数据类型数据类型 布尔型数据布尔型数据l布尔型变量的说明:布尔型变量的说明:例:例:boolbool flag flag;l布尔型数据的取值:布尔型数据的取值:只有只有 falsefalse 和和 truetrue 两个值两个值基本数据类型和表达式C+语言程序设计16 数据类型数据类型 变量初始化变量初始化例:例:intint a=3;a=3;double f=3.56;double f=3.56;char c=a;char c=a;intint c(5);c(5);Page 16基本数据类型和表达式C+语言程序设计17数据类型数据类型 混合运算时的类型转换混合运算时的类型转换l不同类型数据进行混合运算时,不同类型数据进行混合运算时,C+C+编译器编译器会自动进行类型转换。会自动进行类型转换。l为了避免不同的数据类型在运算中出现类为了避免不同的数据类型在运算中出现类型问题,应尽量使用同种类型数据。型问题,应尽量使用同种类型数据。l可以采用强制类型转换:可以采用强制类型转换:例如:float c;int a,b;c=float(a)/float(b);或 c=(float)a/(float)b;基本数据类型和表达式C+语言程序设计18变量的存储类型变量的存储类型lautoauto属于一时性存储,其存储空间可以被若干变量多次覆盖使用。lregisterregister存放在通用寄存器中。lexternextern在所有函数和程序段中都可引用。lstaticstatic在内存中是以固定地址存放的,在整个程序运行期间都有效。基本数据类型和表达式C+语言程序设计19算术运算符与算术表达式算术运算符与算术表达式l基本算术运算符基本算术运算符 +-*/(若整数相除,结果取整)%(取余,操作数为整数)l优先级与结合性优先级与结合性先乘除,后加减,同级自左至右l+,-+,-(自增、自减)(自增、自减)例:i+;-j;Page 19基本数据类型和表达式C+语言程序设计20赋值运算符和赋值表达式赋值运算符和赋值表达式 简单的赋值运算符简单的赋值运算符=l举例举例n=n+5n=n+5l表达式的类型表达式的类型等号左边对象的类型等号左边对象的类型l表达式的值表达式的值等号左边对象被赋值后的值等号左边对象被赋值后的值Page 20基本数据类型和表达式C+语言程序设计21赋值运算符和赋值表达式赋值运算符和赋值表达式 复合的赋值运算符复合的赋值运算符l有有1010种复合运算符:种复合运算符:+=,-=,*=,/=,%=,+=,-=,*=,/=,%=,=,&=,=,|=,&=,=,|=l例例a a+=3 3 等价于等价于 a=a=a a+3+3x x*=y+8y+8 等价于等价于 x=x=x x*(y+8)*(y+8)基本数据类型和表达式C+语言程序设计22赋值运算符和赋值表达式赋值运算符和赋值表达式 赋值表达式举例赋值表达式举例a=5表达式值为5a=b=c=5表达式值为5,a,b,c均为5a=5+(c=6)表达式值为11,a为11,c为6a=(b=4)+(c=6)表达式值为10,a为10,b为4,c为6a=(b=10)/(c=2)表达式值为5,a为5,b为10,c为2a+=a-=a*a 相当于 a=a+(a=a-a*a)Page 22基本数据类型和表达式C+语言程序设计23逗号运算和逗号表达式逗号运算和逗号表达式l格式格式表达式1,表达式2l求解顺序及结果求解顺序及结果先求解1,再求解2,最终结果为表达式2的值l例例a=3*5,a*4 最终结果为60Page 23基本数据类型和表达式C+语言程序设计24关系运算与关系表达式关系运算与关系表达式l关系运算是比较简单的一种逻辑运算,优先关系运算是比较简单的一种逻辑运算,优先次序为:次序为:=!=!=优先级相同(高)优先级相同(高)优先级相同(低)优先级相同(低)l 关系表达式是一种最简单的逻辑表达式关系表达式是一种最简单的逻辑表达式其结果类型为 bool,值只能为 true 或 false。l例如:例如:a a b b,c c=b)b)&(x(x y)y)其结果类型为其结果类型为 boolbool,值只能为,值只能为 truetrue 或或 falsefalse基本数据类型和表达式C+语言程序设计26逻辑运算与逻辑表达式逻辑运算与逻辑表达式l l“&”的的“短路特性短路特性”表达式表达式1&1&表达式表达式2 2先求解表达式先求解表达式1 1若表达式若表达式1 1的值为的值为falsefalse,则最终结果为,则最终结果为falsefalse,不再求解表达式不再求解表达式不再求解表达式不再求解表达式2 2 2 2若表达式若表达式1 1的结果为的结果为truetrue,则求解表达式,则求解表达式2 2,以表达式,以表达式2 2的结果作为最终结果的结果作为最终结果l l“|”也具有类似的特性也具有类似的特性基本数据类型和表达式C+语言程序设计27条件运算符与条件表达式条件运算符与条件表达式l一般形式一般形式表达式1?表达式2:表达式3表达式1 必须是 bool 类型l执行顺序执行顺序先求解表达式1,若表达式1的值为true,则求解表达式2,表达式2的值为最终结果若表达式1的值为false,则求解表达式3,表达式3的值为最终结果l例:例:x=a b?a:b;x=a b?a:b;基本数据类型和表达式C+语言程序设计28条件运算符与条件表达式条件运算符与条件表达式l注意:注意:条件运算符优先级高于赋值运算符,低于逻辑运算符表达式2、3的类型可以不同,条件表达式的最终类型为 2 和 3 中较高的类型。l例:例:x x=a a b b?a a:b;b;基本数据类型和表达式C+语言程序设计29sizeof 运算符运算符l语法形式语法形式sizeofsizeof(类型名类型名)或或 sizeofsizeof 表达式表达式l结果值:结果值:“类型名类型名”所指定的类型或所指定的类型或“表达式表达式”的结果的结果类型所占的字节数。类型所占的字节数。l例:例:sizeof(short)sizeof x基本数据类型和表达式C+语言程序设计30位运算位运算按位与(按位与(&)l运算规则运算规则将两个运算量的每一个位进行逻辑与操作l举例:计算举例:计算 3&53&5 3:0 0 0 0 0 0 1 1 5:(&)0 0 0 0 0 1 0 13&5:0 0 0 0 0 0 0 1l用途:用途:将某一位置0,其他位不变。例如:将char型变量a的最低位置0:a=a&0 xfe;取指定位。例如:有char c;int a;取出a的低字节,置于c中:c=a&0 xff;基本数据类型和表达式C+语言程序设计31位运算位运算按位或(按位或(|)l运算规则运算规则将两个运算量的每一个位进行逻辑或操作l举例:计算举例:计算 3|53|5 3:0 0 0 0 0 0 1 1 5:(|)0 0 0 0 0 1 0 13|5:0 0 0 0 0 1 1 1l用途:用途:将某些位置1,其他位不变。例如:将 int 型变量 a 的低字节置 1:a=a|0 xff;基本数据类型和表达式C+语言程序设计32位运算位运算按位异或(按位异或()l运算规则运算规则两个操作数进行异或:若对应位相同,则结果该位为 0,若对应位不同,则结果该位为 1,l举例:计算举例:计算 071052071052 071:0 0 1 1 1 0 0 1 052:()0 0 1 0 1 0 1 0 071052:0 0 0 1 0 0 1 1基本数据类型和表达式C+语言程序设计33位运算位运算按位异或(按位异或()l用途:用途:使特定位翻转(与0异或保持原值,与1异或取反)例如:要使 01111010 低四位翻转:0 1 1 1 1 0 1 0 ()0 0 0 0 1 1 1 10 1 1 1 0 1 0 1基本数据类型和表达式C+语言程序设计34位运算位运算取反取反()()单目运算符,对一个二进制数按位取反。单目运算符,对一个二进制数按位取反。例:025:0000000000010101 025:1111111111101010基本数据类型和表达式C+语言程序设计35位运算位运算移位移位l左移运算(左移运算()右移后,低位:舍弃高位:无符号数:补0 有符号数:补“符号位”基本数据类型和表达式C+语言程序设计36运算符优先级运算符优先级括号括号+,-,sizeofsizeof*,/,%*,/,%+,-+,-=,!=,!=位运算位运算&|?:?:赋值运算赋值运算逗号运算逗号运算低高基本数据类型和表达式C+语言程序设计37混合运算时数据类型的转换混合运算时数据类型的转换 隐含转换隐含转换l一些二元运算符(算术运算符、关系运算符、逻辑一些二元运算符(算术运算符、关系运算符、逻辑运算符、位运算符和赋值运算符)要求两个操作数运算符、位运算符和赋值运算符)要求两个操作数的类型一致。的类型一致。l在算术运算和关系运算中如果参与运算的操作数类在算术运算和关系运算中如果参与运算的操作数类型不一致,编译系统会自动对数据进行转换(即隐型不一致,编译系统会自动对数据进行转换(即隐含转换),基本原则是将低类型数据转换为高类型含转换),基本原则是将低类型数据转换为高类型数据。数据。char,short,int,unsigned,long,unsigned long,float,double低 高基本数据类型和表达式C+语言程序设计38混合运算时数据类型的转换混合运算时数据类型的转换 隐含转换隐含转换l当参与运算的操作数必须是当参与运算的操作数必须是bool型时,如果操作数型时,如果操作数是其它类型,编译系统会自动将非是其它类型,编译系统会自动将非0数据转换为数据转换为true,0转换为转换为false。l位运算的操作数必须是整数,当二元位运算的操作位运算的操作数必须是整数,当二元位运算的操作数是不同类型的整数时,也会自动进行类型转换,数是不同类型的整数时,也会自动进行类型转换,l赋值运算要求左值与右值的类型相同,若类型不同,赋值运算要求左值与右值的类型相同,若类型不同,编译系统会自动将右值转换为左值的类型。编译系统会自动将右值转换为左值的类型。基本数据类型和表达式C+语言程序设计39混合运算时数据类型的转换混合运算时数据类型的转换 显式转换显式转换l语法形式(语法形式(3 3种):种):类型说明符(表达式)(类型说明符)表达式类型转换操作符(表达式)l类型转换操作符可以是:const_cast、dynamic_cast、reinterpret_cast、static_castl显式类型转换的作用是将表达式的结果类型显式类型转换的作用是将表达式的结果类型转换为类型说明符所指定的类型。转换为类型说明符所指定的类型。l例:例:int(zint(z),(),(int)zint)z,static_caststatic_cast(z)(z)三种完全等价三种完全等价基本数据类型和表达式C+语言程序设计40语句语句l空语句空语句l声明语句声明语句l表达式语句表达式语句l选择语句选择语句l循环语句循环语句l跳转语句跳转语句l复合语句复合语句l标号语句标号语句 C+语言程序设计41表达式语句表达式语句l格式:格式:表达式;l表达式语句与表达式的区别:表达式语句与表达式的区别:表达式可以包含在其他表达式中,而语句不可。例如:if(a=b)0)t=a;不可写为:if(a=b;)0)t=a;语 句C+语言程序设计42复合语句复合语句l将多个语句用一对大括号包围,便构将多个语句用一对大括号包围,便构成一个复合语句成一个复合语句l例如例如sum=sum+i;i+;语 句C+语言程序设计43简单的输入、输出简单的输入、输出l向标准输出设备(显示器)输出向标准输出设备(显示器)输出例:int x;cout x=x;C+语言程序设计44顺序结构顺序结构分支结构分支结构循环结构循环结构算法的基本控制结构算法的基本控制结构C+语言程序设计45如何解决分支问题如何解决分支问题?例例2-2输入一个年份,判断是否闰年。输入一个年份,判断是否闰年。算法的基本控制结构#include#include using namespace std;using namespace std;int main()int main()int year;int year;bool IsLeapYear;bool IsLeapYear;cout cout year;year;IsLeapYear=(year%4=0&IsLeapYear=(year%4=0&year%100!=0)year%100!=0)|(year%400=0);(year%400=0);if(IsLeapYear)if(IsLeapYear)coutcout yearyear is a leap year is a leap year“endl;endl;elseelse coutcout yearyear is not a leap year is not a leap year“endl;y)cout y)cout x;else cout y;if(if(表达式表达式1)1)语句语句1 1else if(else if(表达式表达式2)2)语句语句2 2else if(else if(表达式表达式3)3)语句语句3 3 else else 语句语句 n n if if 语句语句 三种形式三种形式算法的基本控制结构C+语言程序设计49如何解决多分问题如何解决多分问题?例例2-3 输入两个整数,比较两个数的大小。输入两个整数,比较两个数的大小。算法的基本控制结构#include#includeusing namespace std;using namespace std;int main()int main()int x,y;int x,y;cout Enter x and y:;cout x y;cin x y;if(x!=y)if(x!=y)if(x y)if(x y)cout y endl;cout y endl;elseelsecout x y endl;cout x y endl;elseelsecout x=y endl;cout x=y endl;return 0;return 0;50运行结果运行结果1 1:Enter x and y:5 8Enter x and y:5 8x yx yx y51C+语言程序设计52l一般形式一般形式if()if()语句 1 else 语句 2else if()语句 3 else 语句 4l注意注意语句 1、2、3、4 可以是复合语句,每层的 if 与 else 配对,或用 来确定层次关系。if if 语句语句 嵌套嵌套算法的基本控制结构C+语言程序设计53特殊的多分支结构特殊的多分支结构例例2-4输入一个输入一个06的整数,转换成星期输出。的整数,转换成星期输出。算法的基本控制结构#include include using namespace std;using namespace std;int main()int main()int day;int day;cin day;cin day;switch(day)switch(day)case 0:case 0:coutcout SundaySunday endl;endl;break;break;case 1:case 1:coutcout MondayMonday endl;endl;break;break;case 2:case 2:coutcout TuesdayTuesday endl;endl;break;break;case 3:coutcase 3:cout WednesdayWednesday endl;endl;break;break;case 4:case 4:coutcout ThursdayThursday endl;endl;break;break;case 5:case 5:coutcout FridayFriday endl;endl;break;break;case 6:case 6:coutcout SaturdaySaturday endl;endl;break;break;default:default:coutcout Day out of range Sunday.SaturdayDay out of range Sunday.Saturday endl;endl;break;break;return 0;return 0;54C+语言程序设计55l一般形式一般形式switch (表达式)case 常量表达式 1:语句1 case 常量表达式 2:语句2 case 常量表达式 n:语句n default:语句n+1 switch switch 语句语句l执行顺序执行顺序以case中的常量表达式值为入口标号,由此开始顺序执行。因此,每个case分支最后应该加break语句。每个常量表达式的值不能相同,次序不影响执行结果。可以是多个语句,但不必用。可以是整型、字符型、枚举型算法的基本控制结构C+语言程序设计56使用使用switchswitch语句应注意的问题语句应注意的问题lcasecase分支可包含多个语句,且不用分支可包含多个语句,且不用 。l表达式、判断值都是表达式、判断值都是intint型或型或charchar型。型。l若干分支执行内容相同可共用一组语若干分支执行内容相同可共用一组语句。句。算法的基本控制结构C+语言程序设计57如何有效地完成重复工作如何有效地完成重复工作例例2-52-5求自然数求自然数1 11010之和之和分析:本题需要用累加算法,累加过分析:本题需要用累加算法,累加过程是一个循环过程,可以用程是一个循环过程,可以用whilewhile语句语句实现。实现。算法的基本控制结构#include#include using namespace std;using namespace std;int main()int main()int i=1,sum=0;int i=1,sum=0;while(i=10)while(i=10)sum+=i;sum+=i;/相当于sum=sum+i;i+;i+;cout sum=sum endl;cout sum=sum endl;return 0;return 0;运行结果:运行结果:sum=5558C+语言程序设计59while while 语句语句l形式形式while (表达式)语句可以是复合语句,其中必须含有改变条件表达式值的语句。l执行顺序执行顺序先判断表达式的值,若为 true 时,执行语句。算法的基本控制结构C+语言程序设计60先执行循环体,后判断条件的情况先执行循环体,后判断条件的情况例例2-62-6 输入一个整数,将各位数字反转后输入一个整数,将各位数字反转后输出。输出。算法的基本控制结构#include include using namespace std;using namespace std;int main()int main()int n,right_digit,newnum=0;int n,right_digit,newnum=0;cout Enter the number:;cout n;cin n;cout The number in reverse order is ;cout The number in reverse order is ;dodo right_digit=n%10;right_digit=n%10;cout right_digit;cout right_digit;n/=10;n/=10;/相当于n=n/10 while(n!=0)while(n!=0);cout endl;cout endl;return 0;return 0;61运行结果:运行结果:Enter the number:365Enter the number:365The number in reverse order is 563The number in reverse order is 56362C+语言程序设计63do-while do-while 语句语句l一般形式一般形式do 语句while(表达式)可以是复合语句,其中必须含有改变条件表达式值的语句。l执行顺序执行顺序先执行循环体语句,后判断条件。表达式为 true 时,继续执行循环体l与与whilewhile语句的比较:语句的比较:while 语句执行顺序 先判断表达式的值,为true时,再执行语句算法的基本控制结构对比下列程序:对比下列程序:程序程序1 1:#include#include using namespace std;using namespace std;int main()int main()int i,sum=0;int i,sum=0;cin i;cin i;while(i=10)while(i=10)sum+=i;sum+=i;i+;i+;cout sum=sum cout sum=sum endl;endl;return 0;return 0;算法的基本控制结构程序程序2 2:#include#include using namespace std;using namespace std;int main()int main()int i,sum=0;int i,sum=0;cin i;cin i;do do sum+=i;sum+=i;i+;i+;while(i=10)while(i=10);cout sum=sumcout sum=sum endl;endl;return 0;return 0;64C+语言程序设计65for for 语句语句语法形式语法形式for (初始语句;表达式1;表达式2)语句 循环前先求解为true时执行循环体每次执行完循环体后求解算法的基本控制结构C+语言程序设计66例例2-8输入一个整数,求出它的所有因子。输入一个整数,求出它的所有因子。算法的基本控制结构#include include using namespace std;using namespace std;int main()int main()int n;int n;cout Enter a positive integer:;cout n;cin n;cout Number n Factors ;cout Number n Factors ;for(for(int int k k =1;k=n;k+)1;k=n;k+)if(n%k=0)if(n%k=0)cout k ;cout k ;cout endl;cout endl;return 0;return 0;67运行结果运行结果1 1:Enter a positive integer:36Enter a positive integer:36Number 36 Factors 1 2 3 4 6 9 12 18 36 Number 36 Factors 1 2 3 4 6 9 12 18 36 运行结果运行结果2 2:Enter a positive integer:7Enter a positive integer:7Number 7 Factors 1 7 Number 7 Factors 1 7 68C+语言程序设计69例例2-9 编写程序输出以下图案编写程序输出以下图案 *算法的基本控制结构#include#include using namespace std;using namespace std;int main()int main()const int N=4;const int N=4;for(int i=1;i=N;i+)for(int i=1;i=N;i+)/输出前输出前4 4行图案行图案 for(int j=1;j=30;j+)for(int j=1;j=30;j+)cout ;cout ;/在图案左侧空在图案左侧空3030列列 for(int j=1;j=8-2*i;j+)for(int j=1;j=8-2*i;j+)cout ;cout ;for(int j=1;j=2*i-1;j+)for(int j=1;j=2*i-1;j+)cout *;cout *;cout endl;cout endl;70/输出后输出后3 3行图案行图案for(int i=1;i=N-1;i+)for(int i=1;i=N-1;i+)for(int j=1;j=30;j+)for(int j=1;j=30;j+)cout ;cout ;/在图案左侧空在图案左侧空3030列列 for(int j=1;j=7-2*i;j+)for(int j=1;j=7-2*i;j+)cout *;cout *;cout endl;cout endl;return 0;return 0;71C+语言程序设计72循环结构与选择结构相互嵌套循环结构与选择结构相互嵌套#include#include using namespace std;using namespace std;int main()int main()for(int n=100;n=200;n+)for(int n=100;n=200;n+)if if(n%3!=0)(n%3!=0)cout n;cout n;return 0;return 0;算法的基本控制结构C+语言程序设计73例例2-102-10l读入一系列整数,统计出正整数个数读入一系列整数,统计出正整数个数i i和负整数个数和负整数个数j,j,读入读入0 0则结束。则结束。l分析:分析:需要读入一系列整数,但是整数个数不定,要在每次读入之后进行判断,因此使用while循环最为合适。循环控制条件应该是n!=0。由于要判断数的正负并分别进行统计,所以需要在循环内部嵌入选择结构。算法的基本控制结构#include#include using namespace std;using namespace std;int main()int main()int i=0,j=0,n;int i=0,j=0,n;cout Enter some integers please(enter 0 to quit):cout Enter some integers please(enter 0 to quit):endl;n;cin n;while(n!=0)while(n!=0)if(n 0)i+=1;if(n 0)i+=1;if(n 0)j+=1;if(n n;cin n;cout Count of positive integers:i endl;cout Count of positive integers:i endl;cout Count of negative integers:j endl;cout Count of negative integers:j endl;return 0;return 0;74C+语言程序设计75break break 和和 continue continue 语句语句lbreakbreak语句语句使程序从循环体和switch语句内跳出,继续执行逻辑上的下一条语句。不宜用在别处。lcontinue continue 语句语句结束本次循环,接着判断是否执行下一次循环。算法的基本控制结构C+语言程序设计76typedef语句语句l为一个已有的数据类型另外命名为一个已有的数据类型另外命名l语法形式语法形式typedef 已有类型名 新类型名表;l例如例如typedef double Area,Volume;typedef int Natural;Natural i1,i2;Area a;Volume v;自定义数据类型C+语言程序设计77枚举类型枚举类型enuml只要将需要的变量值一一列举出来,只要将需要的变量值一一列举出来,便构成了一个枚举类型。便构成了一个枚举类型。l枚举类型的声明形式如下:枚举类型的声明形式如下:enum 枚举类型名 变量值列表;l例如:例如:enum WeekdaySUN,MON,TUE,WED,THU,FRI,SAT;自定义数据类型C+语言程序设计78枚举类型枚举类型enuml枚举类型应用说明:枚举类型应用

    注意事项

    本文(第2章 C简单程序设计.ppt)为本站会员(qwe****56)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开