第七章自定义数据类型.ppt

  1. 1、本文档共58页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第七章 结构体与共用体 7.1 .1结构体 结构体是一种构造数据类型 用途:把不同类型的数据组合成一个整体-------自定义数据类型 结构体类型定义 7.1.2 结构体变量的定义 先定义结构体类型,再定义结构体变量 一般形式: 定义结构体类型的同时定义结构体变量 一般形式: 7.1.3 结构体变量的引用 引用规则 结构体变量不能整体引用,只能引用变量成员 结构体变量的初始化 形式一: 7.1.4 结构体数组 结构体数组的定义 三种形式: 结构体数组初始化 7.1.5 结构体和指针 指向结构体变量的指针 定义形式:struct 结构体名 *结构体指针名; 例 struct student *p; 指向结构体数组的指针 7.1.6结构体类型数据作函数参数 用结构体变量的成员作参数----值传递 用指向结构体变量或数组的指针作参数----地址传递 用结构体变量作参数----多值传递,效率低 例7.6 开辟空间以存放一个结构体变量 int main( ) { Student *p; p=new Student; p->name=″Wang Fun″; p->num=10123; p->sex=′m′; cout<<p->name<<endl<<p->num<<endl<<p->sex<<endl; delete p; return 0; } 7.2共用体 构造数据类型,也叫联合体 用途:使几个不同类型的变量共占一段内存(相互覆盖) 共用体类型定义 定义形式: #include <iostream> #include <iomanip> using namespace std; int main( ) { enum color {red,yellow,blue,white,black}; for (i=red;i<=black;i++) for (j=red;j<=black;j++) if (i!=j) { for (k=red;k<=black;k++) if ((k!=i) && (k!=j)) switch (pri) //判断pri的值,输出相应的“颜色” {case red: cout<<setw(8)<<″red″; break; case yellow: cout<<setw(8)<<″yellow″; break; case blue: cout<<setw(8)<<″blue″; break; case white: cout<<setw(8)<<″white″; break; case black: cout<<setw(8)<<″black″; break; default : break; } } cout<<endl; } } cout<<″total:″<<n<<endl; return 0; } typedef定义类型步骤 按定义变量方法先写出定义体 如 int i; 将变量名换成新类型名 如 int INTEGER; 最前面加typedef 如 typedef int INTEGER; 用新类型名定义变量 如 INTEGER i,j; 89.5 31001 head 90 31003 p1 p2 85 31007 p1 p2->next=p1; 89.5 31001 head 90 31003 p2 85 31007 p1 0 0 p1 NULL p2=p1; p2->next=NULL; #include <iostream> using namespace std; #define NULL 0 struct student {long num; float score; student *next; }; int n; student *creat(void) {student *head; student *p1,*p2; n=0; p1=p2=new student; cin>>p1->num>>p1->score; head=NULL; while(p1->num!=0) {n=n+1; if(n==1) head=p1; else p2->next=p1; p2=p1; p1=new student; cin>>p1->num>>p1->score; } p2->next=N

文档评论(0)

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

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

1亿VIP精品文档

相关文档