- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验报告一09419023俞洋洋
算法与数据结构实验报告——实验一
实验名称 抽象数据类型的定义和实现(1)—复数ADT及其实现 成绩 姓 名 俞洋洋 学号班级 网络工程0920 实验
地点 4#200 指导教师 唐仕喜 完成
日期 2010.9.7 实验目的 通过使用复数加减乘除来掌握ADT的使用。;
根据算法,进行结构化程序设计的能力;
对一些典型的基本应用问题,进行算法设计的能力。
设计流程
[复数ADT的描述]
ADT complex{
数据对象:D{c1,c2 c1,c2∈FloatSet}
数据关系:R{c1,c2 c1 c2}
基本操作:创建一个复数 creat(a);
输出一个复数 output(a);
求两个复数相加之和 add(a,b);
求两个复数相减之差 sub(a,b);
求两个复数相乘之积 chengji(a,b);
求两个复数相除之商 xiangchu(a,b);
}ADT complex;
实
验
内
容
与
步
骤
实
验
内
容
与
步
骤 检查所用的计算机系统是否已安装了C编译系统并确定它所在的子目录;
进行所用的集成环境;
熟悉集成环境的界面的有关菜单的使用方法;
建立“复数ADT及其实现”工程。
建立结构体和复数类
#includestdio.h
#includestdlib.h
typedef struct
{
float x;
float y;
}comp;
comp a,b,a1,b1;
int z;
int z1,z2;
class complex
编写成员函数:
public:
void outputc(comp a);
void creat(comp *c);
7)编写运算程序:
两复数相加:
void outputc(comp a)
{
printf(\n z=%f+%f i \n\n,a.x,a.y);
}
comp add(comp k,comp h)
{
comp l;
l.x=k.x+h.x; l.y=k.y+h.y;
printf(相加:);
return(l);
}
两复数相减:
comp sub(comp k,comp h)
{
comp l;
l.x=k.x-h.x; l.y=k.y-h.y;
printf(相减:);
return(l);
}
两复数相乘:
comp mul(comp k,comp h)
{
comp l;
l.x=k.x*h.x-k.y*h.y; l.y=k.x*h.y+k.y*h.x;
printf(相乘:);
return(l);
}
两复数相除:
comp div(comp k,comp h)
{
comp l;
l.x=(k.x*h.x+k.y*h.y)/(h.x*h.x+h.y*h.y);
l.y=(k.y*h.x-k.x*h.y)/(h.x*h.x+h.y*h.y);
printf(相除:);
return(l);
}
8)main 函数实现:
int main(int argc, char* argv[])
{
creat(a); outputc(a);
creat(b); outputc(b);
a1=add(a,b); outputc(a1);
a1=sub(a,b); outputc(a1);
a1=mul(a,b); outputc(a1);
a1=div(a,b); outputc(a1);
return 0;
}
9)算法复杂度分析:
类似于x=x+1,所以程序的时间复杂度为O(1),称之为常量阶。
1)错误分析
Compiling...
01.cpp
D:\C++\01.cpp(13) : error C2143: syntax error : missing ; before public
D:\C++\01.cpp(33) : error C2143: syntax error : missing ; before constant
D:\C++\01.cpp(34) : error C2059: syntax error : bad suffix on number
D:\C++\01.cpp(34) : error C2146: syntax error : missing ; before identifier x
D:\C++\01.cpp(34) :
原创力文档


文档评论(0)