1、JAVA程序设计报告-集合的运算(交并差)学生: 学号: 专业:信息工程(系统工程方向)院系:信息与控制学院实习时间:三周;指导老师:陈金辉 目录实验目的-试验设计-实验源程序-程序设计调试-不足及改进-如何美观-第一章 程序设计目的本次课程设计报告主要是老师对学生综合编程能力的一次评测,在掌握c,java语言的基础上,学会自主的编制一些基本的程序。本次的实验课题是对集合的运算进行实验。在java平台上开发出集合运算的程序。 第二章 程序设计思路一:集合的运算,我们要求的是集合的交并差。首先了解集合的交并差是如何让运算的。掌握运算的思路才能把程序设计思路调试出来。1:集合的交 对于给定的两个集
2、合,要求出给定的两个集合的交集,交集和就是将其中都相同的元素找出来,将之放入第三个集合里,输出第三集合里的元素。如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集合中
3、的所有的元素都找一遍,相同的元素的只将其赋一次值于第三集合里。主要思想是在集合差的基础上,再做一次赋值运算就可以了,由于集合差的运算中,已经找到了中异于中的元素,然后再将中的元素再赋值于第三集合就可以了。A=1,2,3,4;B=2,4,5,6;,;,;二:主要思想:以数组的形式来代替集合,通过数组的运算来进行集合的运算。首先定义数组,再在数组中进行定义一个类,再定义成员变量,构造成员方法,成员方法是对数组也就是集合来进行操作的一种手段。由于是直接赋值了,我们找不到类。我们需要先进行定义一个类NewMain A=new NewMain();A.Aarray=c; A.Barray=d;通过地址调
4、用来完成对数组的调用以及修改,因为我们不仅需要对整形数组进行交并差的运算,还要对实型数组,字符型数组进行运算。为了美化和方便程序,为了能实现一个友好的人机界面,就必须以多种方法的形式出现在你的java程序中。之前,我也试过了将多个函数模块写在主方法中,发现了如下问题:1. 在主方法中要用来存储第A,B中相异的元素的第三集合需要定义很多,和比较的中间变量也比较多。使程序看起来一是冗杂,而是出现问题很多,很难进行调试。2. 难以实现用户的自主性,因为在同一个主方法中,所有的函数都是按照顺序从上往下执行的不能选择性的跳过。这就增加函数的选择的难度。所以想到用多方法定义集合运算,在个定义了一个抽象的数
5、据类型后,还需为这个类型的对象定义相应的操作。分别是整形的,实型的,字符型的交并差的方法。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+=Aarra
6、yi;结果发现这段函数根本实现不了其所期望的功能,根本原因在于他只是找到一个与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.
7、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,
8、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
9、(); 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(集合并的结果是:); Syste
10、m.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(集合
11、没有交集 !请重新检查输入是否合法!); 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
12、,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.printl
13、n(); 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.pr
14、intln(); 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(集合没有交集 !请重新检查输入是否合法!)
15、; 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=n
16、ew 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.print
17、ln(); 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+) S
18、ystem.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.ou
19、t.println(); System.out.println(); System.out.print( ); for(b=0;br;b+) System.out.print(Darrayb+, ); System.out.print( ); public static void main(String args) NewMain A=new NewMain(); int c=1,2,3,4; int d=2,3,5,6; char e=a,b,c,d; /变量赋值操作 char f=c,h,j; double g=1.1,1.3/*/,1.7,2.1,4.0/*/; double h=1.0
20、,1.2/*/,1.4,1.5/*/;/用于修改调试 A.Aarray=c; A.Barray=d; System.out.println(请输入你的选择 按下面提示操作 : ); System.out.println(1 :整形数组 ! 2 : 字符型数组!3 : 字符型数组 !); Scanner a=new Scanner(System.in);/输入函数选择操作 int b=a.nextInt(); switch(b) case 1:A.intjihe();break; case 2: A.charjihe(e,f);break; case 3: A.doublejihe(g,h);
21、java程序运行结果展示,运用NetBeans Ide 6.9.1软件运行:本文是通过网络收集的资料,如有侵权请告知,我会第一时间处理。本店专业 提供 豆丁网 道客巴巴 百度文库 智客(21ask) 文档在线 网站的原始文档下载服务。收费标准:1、 豆丁网: 按照豆丁网原价的50%收取,不收手续费。2、 道客巴巴:按照道客巴巴网站原价的90%收取,不收手续费。3、 百度文库:所有文档,无论多少积分,统一收取1元,不收手续费。4、 智客网: 按照智客网的原价收取,手续费1元。(智客网站 每次充值最少是20元)5、 文档在线:所有文档,无论多少积分,统一收取5元,不收手续费(文档在线网站,每次充值至少20元)。关于发货:(5分钟内完成)1、 通过旺旺发送。2、 通过QQ发送。3、 通过邮箱发送。联系方式:1、 QQ:16405228812、 旺旺:mx5976516613、 邮箱:16405228814、 手机:15018530036(限短信)注意事项:1、 所有文档一经售出概不退款。2、 大家购买时,请按实际的价格选择合适的宝贝数量。否则不予发货。谢谢配合。3、 拍下宝贝时,务必备注清楚文档网站链接地址(或者文档的完整名称)以及邮箱地址。4、 店主在线时再拍,以防止不能及时的给您发货。您有任何疑问,请联系我!欢迎大家前来咨询!营业时间 早上10:30-01:00