




已阅读5页,还剩13页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
JAVA程序设计报告-集合的运算(交并差)学生: 学号: 专业:信息工程(系统工程方向)院系:信息与控制学院实习时间:三周;指导老师:陈金辉 目录实验目的-试验设计-实验源程序-程序设计调试-不足及改进-如何美观-第一章 程序设计目的本次课程设计报告主要是老师对学生综合编程能力的一次评测,在掌握c,java语言的基础上,学会自主的编制一些基本的程序。本次的实验课题是对集合的运算进行实验。在java平台上开发出集合运算的程序。 第二章 程序设计思路一:集合的运算,我们要求的是集合的交并差。首先了解集合的交并差是如何让运算的。掌握运算的思路才能把程序设计思路调试出来。1:集合的交 对于给定的两个集合,要求出给定的两个集合的交集,交集和就是将其中都相同的元素找出来,将之放入第三个集合里,输出第三集合里的元素。如A=1,2,3,4;B=2,4,5,6; C=AB; C=2,4;需要中间变量C需要定义新的数组,int C=new int20; 2:集合的差 对于给定的两个集合,集合的差就是找出A集合中不同于B集合里面的元素,并将之存入第三集合C中,同样也需要引入第三集合,但是寻找A集合中不同于集合B中的方法不是很容易想到。需要先定义一个标记,从标记入手,依次寻找。将在下一章中重点介绍。A=1,2,3,4;B=2,4,5,6;,;3:集合的并 对于给定的两个集合,集合的并就是将A集合与B集合中的所有的元素都找一遍,相同的元素的只将其赋一次值于第三集合里。主要思想是在集合差的基础上,再做一次赋值运算就可以了,由于集合差的运算中,已经找到了中异于中的元素,然后再将中的元素再赋值于第三集合就可以了。A=1,2,3,4;B=2,4,5,6;,;,;二:主要思想:以数组的形式来代替集合,通过数组的运算来进行集合的运算。首先定义数组,再在数组中进行定义一个类,再定义成员变量,构造成员方法,成员方法是对数组也就是集合来进行操作的一种手段。由于是直接赋值了,我们找不到类。我们需要先进行定义一个类NewMain A=new NewMain();A.Aarray=c; A.Barray=d;通过地址调用来完成对数组的调用以及修改,因为我们不仅需要对整形数组进行交并差的运算,还要对实型数组,字符型数组进行运算。为了美化和方便程序,为了能实现一个友好的人机界面,就必须以多种方法的形式出现在你的java程序中。之前,我也试过了将多个函数模块写在主方法中,发现了如下问题:1. 在主方法中要用来存储第A,B中相异的元素的第三集合需要定义很多,和比较的中间变量也比较多。使程序看起来一是冗杂,而是出现问题很多,很难进行调试。2. 难以实现用户的自主性,因为在同一个主方法中,所有的函数都是按照顺序从上往下执行的不能选择性的跳过。这就增加函数的选择的难度。所以想到用多方法定义集合运算,在个定义了一个抽象的数据类型后,还需为这个类型的对象定义相应的操作。分别是整形的,实型的,字符型的交并差的方法。public static void intjihe();public void charjihe(char Aarray,char Barray)等等。其中三种集合的操作都是一样的。只是在形式上以及操作类型上出现一些细微的差别。但是算法本质上没有很大的差别。初始时想通过找到A,B集合中的A异于B的元素于是编出java函数代码。for(i=0;iAarray.length;i+) for(j=0;jBarray.length;j+) if(Aarrayi!=Barrayj) Carray.k+=Aarrayi;结果发现这段函数根本实现不了其所期望的功能,根本原因在于他只是找到一个与B中第一个不一样的元素就输出,终止了操作。其结果肯定是不行的。以下附上正确的源代码:outer: for(i=0;iAarray.length;i+) for(j=0;jBarray.length;j+) if(Aarrayi=Barrayj) continue outer; Carrayk+=Aarrayi;这是在函数还标记了一个位置好让函数在找到不同的元素,还能继续遍历下一个元素直至找到A中所有的元素不同于B的元素,能实现我们的目的。下面附上完整和美化后的函数源代码(函数的功能标记注释):import java.util.Scanner;public class NewMain static int Aarray; static int Barray;/*定义成员变量*/ static char Darray;/=a,b,c,d;/进行函数的测试 static char Earray;/=c,h,j; static double Garray; static double Harray;public static void intjihe()/整形集合的运算方法int Carray=new int20;int Darray=new int20;/开辟中间函数的空间 int i,j,k=0,l,t=0,m,n,r=0,b; outer: for(i=0;iAarray.length;i+) for(j=0;jBarray.length;j+) if(Aarrayi=Barrayj) continue outer;/如果找到相同的返回函数头 继续做 Carrayk+=Aarrayi; t=k; /找到相同的符号(字母,数字,实型): /System.out.println(t=+t);/用于检查t是否进行正确操作 if(t=0) System.out.print(该集合的差集为空集); else System.out.println(集合减的结果是 :); System.out.println(); System.out.print(A-B=); System.out.print( ); for(int g=0;gt;g+) System.out.print(Carrayg+ ,);/输出集合减的结果 System.out.print( ); for(j=0;jBarray.length;j+) Carrayk+=Barrayj; /System.out.println(k);/*检测k赋值多少即是找到A,B中相同的数字多少*/ System.out.println(); System.out.println(); System.out.print(集合并的结果是:); System.out.println(); System.out.print(AuB=); System.out.print( ); for(l=0;lk;l+) System.out.print(Carrayl+ ; ); System.out.print( ); System.out.println(); System.out.println();/换行 用于美化 for(m=0;mAarray.length;m+) for(n=0;nBarray.length;n+) if(Aarraym=Barrayn) Darrayr+=Aarraym; if(r=0) System.out.print(集合没有交集 !请重新检查输入是否合法!); else System.out.print(集合交的结果:);/输出集合交的结果 System.out.print(AB=:); System.out.println(); System.out.print(AB=); System.out.print( ); for(b=0;br;b+) System.out.print(Darrayb+, ); System.out.print( ); public void charjihe(char Aarray,char Barray)/字符型集合运算的方法 int i,j,k=0,l,t=0,m,n,r=0,b; char Carray=new char20; char Darray=new char20; outer: for(i=0;iAarray.length;i+) for(j=0;jBarray.length;j+) if(Aarrayi=Barrayj) continue outer;/如果找到相同的返回函数头 继续做 Carrayk+=Aarrayi; t=k; /System.out.println(t=+t); if(t=0) System.out.print(该集合的差集为空集); System.out.println(集合减的结果是:); System.out.println(); System.out.print( ); for(int g=0;gt;g+) System.out.print(Carrayg+ ,); System.out.print( ); for(j=0;jBarray.length;j+) Carrayk+=Barrayj; /System.out.println(k);/*检测k赋值多少即是找到A,B中相同的数字多少*/ System.out.println(); System.out.println(); System.out.print(集合并的结果是:);/找到不相同的目标后,把另外一个数组的元素调进去 System.out.println(); System.out.println(); System.out.print( ); for(l=0;lk;l+) System.out.print(Carrayl+; ); System.out.print( ); System.out.println(); System.out.println(); for(m=0;mAarray.length;m+) for(n=0;nBarray.length;n+) if(Aarraym=Barrayn) Darrayr+=Aarraym; if(r=0) System.out.print(集合没有交集 !请重新检查输入是否合法!); else System.out.print(AB交集的结果是 :); System.out.print(AB=:); System.out.println(); System.out.println(); System.out.print( ); for(b=0;br;b+) System.out.print(Darrayb+, ); System.out.print( ); public void doublejihe(double Aarray,double Barray)/double型数据处理 int i,j,k=0,l,t=0,m,n,r=0,b; double Darray=new double20; double Carray=new double20; outer: for(i=0;iAarray.length;i+) for(j=0;jBarray.length;j+) if(Aarrayi=Barrayj) continue outer; Carrayk+=Aarrayi; t=k; /寻找异于B中的数 /System.out.println(t=+t);/用于检查t是否进行正确操作 if(t=0) System.out.print(该集合的差集为空集); else System.out.println(集合减的结果是:); System.out.println(); System.out.print( ); for(int g=0;gt;g+) System.out.print(Carrayg+ ,); System.out.print( ); for(j=0;jBarray.length;j+)/转移操作 Carrayk+=Barrayj; System.out.println(); System.out.println(); System.out.print(AB并的结果是:); System.out.println(); System.out.println(); System.out.print( ); for(l=0;lk;l+) System.out.print(Carrayl+; ); System.out.print( ); System.out.println(); System.out.println(); for(m=0;mAarray.length;m+) for(n=0;nBarray.length;n+) if(Aarraym=Barrayn) Darrayr+=Aarraym; if(r=0) System.out.print(集合没有交集 !请重新检查输入是否合法!); else System.out.print(集合交的结果是:); System.out.print(AB=:); System.out.println(); System.out.println();
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 软件技术员考试应试能力训练试题及答案
- 高考数学人物访谈及试题及答案
- 自我反思与生活的启示-高考作文考试试题及答案
- 法学概论的历史发展脉络及试题与答案
- 商铺委托转租协议
- 2025年网络安全评估标准试题及答案
- 基于云计算的仓库管理新模式计划
- 学术活动组织与实施方案计划
- 2025年软考软件设计师答题技巧试题及答案
- 软考网络标准化知识试题及答案
- 2025年河南省洛阳市中考数学一模试卷
- 2025年武汉铁路局集团招聘(180人)笔试参考题库附带答案详解
- 信息安全管理员-初级工练习题(附答案)
- 深圳学位锁定合同协议
- 2025全国不动产登记代理人《不动产登记代理实务》考试真题(附完整解析)
- 农产品供应链应急保障措施
- 食品原料报废管理制度
- 2025年高级政工师理论考试题库(浓缩500题)
- 乡村振兴学习课件
- 2025年施工现场质量员继续教育考试题库(继续教育)含答案
- 饲料企业安全生产工作计划
评论
0/150
提交评论