网站大量收购闲置独家精品文档,联系QQ:2885784924

6复合数据的描述.pptx

  1. 1、本文档共87页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
6复合数据的描述课案

六、复合数据的描述 ??构造数据类型;主要内容;构造数据类型;枚举类型;枚举类型的定义;默认情况下,第一个枚举值为0,其它的值为前一个值加1。 在定义枚举类型时,也可显式地给枚举值指定值。例如: enum Day {SUN=7,MON=1,TUE,WED,THU,FRI,SAT}; TUE为2,... bool类型可看成是C++语言提供的一个预定义的枚举类型: enum bool { false, true };;枚举类型变量的定义;枚举类型的运算;比较 枚举值之间的比较为枚举值所对应的整数之间的比较。例: MON TUE(结果为true) 算术运算 运算时,枚举值将转换成对应的整型值。 对枚举类型进行算术运算的结果类型为算术类型。例如: Day d; int i; ...... i = d+1; //OK d = d+1; //Error,因为d+1的结果为int类型。 d = (Day)(d+1) //OK 不能对枚举类型的值直接进行输入,但可以进行输出。例如: Day d; cin d; //Error cout d; //OK,将把d转换成int;枚举类型输入/输出举例; ...... switch (d) { case SUN: cout SUN endl; break; case MON: cout MON endl; break; case TUE: cout TUE endl; break; case WED: cout WED endl; break; case THU: cout THU endl; break; case FRI: cout FRI endl; break; case SAT: cout SAT endl; break; } return 0; };数组类型;一维数组 ;一维数组类型定义;一维数组类型变量定义格式为: 一维数组类型名 一维数组变量名; 或 元素类型 一维数组变量名[元素个数]; 元素类型为任意C++类型(void除外) 元素个数为整型常量表达式 例如: typedef int A[10]; A a; //由10个int型元素所构成的数组变量。 或 int a[10]; //由10个int型元素所构成的数组变量。;一维数组变量的初始化;一维数组的操作;可把数组的每个元素看成是独立的变量。例如: int a[10]; int sum=0,i; for (i=0; i10; i++) cin a[i]; for (i=0; i10; i++) sum += a[i]; 不能对两个数组进行整体赋值,需要通过元素来进行: int a[10],b[10]; ..... a = b; //Error for (int i=0; i10; i++) a[i] = b[i]; //OK;例:用一维数组实现求第n个费波那契(Fibonacci)数 ;例:从键盘输入10个数,输出其中的最大值;数组应用:求解约瑟夫(Josephus)问题;报数采用下面的方法来实现: 从编号为0的小孩开始报数,用变量index表示要报数的小孩的下标,其初始值为N-1(即将报数的前一个小孩的下标)。 下一个要报数的小孩的下标由下面式子计算: index = (index+1)%N 用变量count来对成功的报数进行计数, 每一轮报数前,count为0,每成功地报一次数,就把count加1,直到M为止。 要使得报数成功,in_circle[index]应为true。 报数成功后,把in_circle[index]设成false。 用变量num_of_children_remained表示圈中剩下的小孩数目,其初始值为N。 ;//变量num_of_children_remained表示圈中剩下的小孩数目,其初始值为N //变量count来对成功的报数进行计数 //变量index表示要报数的小孩的位置 #include iostream using namespace std; const int N=20,M=5; int main() { bool in_circle[N]; int num_of_children_remained,index; //初始化数组in_circle。 for (index=0; indexN; index++) in_circle[index] = true;; //开始报数 index = N-1; //从编号为0的小孩开始报数, //index为前一个小孩的位置。 num_of_children_remained = N; //报数前的圈子中小孩个

文档评论(0)

jiayou10 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8133070117000003

1亿VIP精品文档

相关文档