复数运算2010810071何荣贤.doc_第1页
复数运算2010810071何荣贤.doc_第2页
复数运算2010810071何荣贤.doc_第3页
复数运算2010810071何荣贤.doc_第4页
复数运算2010810071何荣贤.doc_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

集美大学计算机工程学院实验报告课程名称: 数据结构与算法班级:计算1013实验成绩:指导老师:杨艳华姓名:何荣贤实验名称:复数四则运算学号:2010810071上机时间2011年9月6号编号:01组号;11上机完成时间:2学时一. 实验目的 熟悉抽象数据类型的表示和实现方法。抽象数据类型需借助固有数据类型表示和实现,及利用高级程序设计语言中已存在的数据类型来说明新的结构,用已经实现的操作来组合新的操作,具体实现细节则依赖于所用的语言的功能。通过本次实习还可以帮助读者复习高级语言的使用方法。二.实验内容1问题描述 设计一个可进行复数运算的演示程序2基本要求实现下列六种基本运算:1)由输入的实部和虚部生成一个复数;2)两个复数求和;3)两个复数求差;4)两个复数的求积;5)从已知复数中分离出实部;6)从已知复数中分离出虚部。运算结果以相应的复数或实数的表示形式显示。3程序代码#include #include typedef struct Complex float real; float image;Complex;Complex CreatCom(float real,float image); Complex jia(Complex c1,Complex c2);/*复数相加*/Complex jian(Complex c1,Complex c2);/*复数相减*/Complex cheng(Complex c1,Complex c2);/*复数相乘*/Complex chu(Complex c1,Complex c2);/*复数相除*/void PrintCom(Complex c1); /*输出复数*/main() Complex c1,c2,c3; float Real1=0,Image1=0,Real2=0,Image2=0; /*没有输入默认为0 */ int choice,flag=0; printf(*复数运算*n);printf(ttt1.复数构造nttt2.复数相加nttt3.复数相减n);printf(ttt4.复数相乘nttt5.复数相除nttt6.提取实部n);printf(ttt7.提取虚部nttt0.退出ntttn); printf(*n); while(1) /*用循环实现选择不同的运算*/ printf(n输入你的操作序号:); scanf(%d,&choice); switch(choice)case 1:printf(输入第一个复数的实部和虚部:);scanf(%f,%f,&Real1,&Image1);c1=CreatCom(Real1,Image1);PrintCom(c1);printf(输入第二个复数的实部和虚部:);scanf(%f,%f,&Real2,&Image2);c2=CreatCom(Real2,Image2);PrintCom(c2);flag=1;break; case 2: if(flag=1)c3=jia(c1,c2);printf(两数之和是:);PrintCom(c3);else printf(您还未构造复数!n); break; case 3: if(flag=1)c3=jian(c1,c2);printf(两数之差是:);PrintCom(c3);else printf(您还未构造复数!n); break;case 4:if(flag=1)c3=cheng(c1,c2);printf(两数之积是:);PrintCom(c3);else printf(您还未构造复数!n); break;case 5:if(flag=1)c3=chu(c1,c2);printf(两数之商是:);PrintCom(c3);else printf(您还未构造复数!n); break;case 6:if(flag=1)printf(第一个复数实部为:%.2fn,c1.real);printf(第二个复数实部为:%.2fn,c2.real);else printf(您还未构造复数!n); break;case 7:if(flag=1)printf(第一个复数虚部为:%.2fin,c1.image);printf(第二个复数虚部为:%.2fin,c2.image);else printf(您还未构造复数!n); break; case 0: break; default: printf(非法操作!n); break;/*输入其他数字提示错误 */ /*switch*/ if(choice=0) break; /*如果选择了0,退出循环*/ /*while*/Complex CreatCom(float real,float image) Complex NewCom; NewCom.real=real; NewCom.image=image; return NewCom;Complex jia(Complex c1,Complex c2) Complex AddComplex; AddComplex.real=c1.real+c2.real; AddComplex.image=c1.image+c2.image; return AddComplex;Complex jian(Complex c1,Complex c2) Complex SubComplex; SubComplex.real=c1.real-c2.real; SubComplex.image=c1.image-c2.image; return SubComplex;Complex cheng(Complex c1,Complex c2) Complex MulComplex; MulComplex.real=(c1.real*c2.real)-(c1.image*c2.image); MulComplex.image=(c1.real*c2.image)+(c1.image*c2.real); return MulComplex;Complex chu(Complex c1,Complex c2) Complex DivComplex; DivComplex.real=(c1.real*c2.real)+(c1.image*c2.image)/(c2.real*c2.real+c2.image*c2.image); DivComplex.image=(c1.image*c2.real)-(c1.real*c2.image)/(c2.real*c2.real+c2.image*c2.image); return DivComplex;void PrintCom(Complex c1) if(c1.image0|c1.image=0) /*根据虚部的正负用不同的现实格式*/ if(c1.real!=0&c1.image!=0) printf(%.2f+%.2fin,c1.real,c1.image); else if(c1.real=0&c1.image!=0) /*如果虚部或者实部为零,则不显示0*/ printf(%.2fin,c1.image); else if(c1.real!=0&c1.image=0) printf(%.2fn,c1.real); else if(c1.real=0&c1.image=0) printf(%.2fn,c1.real); else if(c1.real!=0&c1.image!=0) printf(%.2f-%.2fin,c1.real,-c1.image); else if(c1.real=0&c1.image!=0) /*如果虚部或者

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论