版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、一、题目要求:用 Java 语言实现单链表的基本操作,并实现集合的交、并和差运算;二、程序功能定义:1、输出两个集合的交集,即找出两个集合的相同元素;2、输出两个集合的并集,即把两个集合的全部元素不重复的加起来;3、输出两个集合的差集,即从一个集合中找出另一个集合里没有的元素;三、设计思路:程序 1: 单链表结点public class Node /单链表结点类,T 指定结点的元素类型 public T data; /数据域,储存数据元素public Node next; /地址域,引用后继结点 public NodeT data, Node next /构造结点, data 指定数据元素,
2、next 指定后继结点 this.data = data; this.next = next; public Node thisnull, null; 程序 2:import java.util.ArrayList; public class SinglyList public Node head; public int length; /以上为默认构造方法,构造空单链表 public static ArrayList union=new ArrayList; public SinglyList this.head = new Node; /以上为构造单链表 public SinglyList
3、T element this; /创建空单链表,只有头结点 this.length = element.length; Node rear = this.head; /rear 指向单链表最终一个结点for int i = 0; i element.length; i+ /如 element=null ,跑出空对象反常; element.length=0 时,构造空链表rear.next = new Nodeelementi, null; /创建结点链入rear 结点之后rear = rear.next; /rear 指向性的链尾结点 public String toString String
4、 str = ; Node p = this.head.next; while p .= null str += p.data.toString; if p.next .= null str += ,; /不是最终一个结点时,后加分隔符 p = p.next; return str + ; /空表返回 public String addAllSinglyList list Node p = this.head.next; String str = ; while p .= null Node q = list.head.next; while q .= null if p.data.toStr
5、ing.equalsq.data.toString if .str.equals str += ,; /集合的元素值相等 /用逗号间隔 str += p.data.toString; this.union.addp.data.toString ; q = q.next; p = p.next; return str + ; /以上为求交集过程;public String unionSinglyList list Node p = this.head.next; String str = ; while p .= null Node q = list.head.next; int i = 0;
6、while q .= null if .p.data.toString.equalsq.data.toString i+; if i = list.length forint a=0;aunion.size;a+ if .p.data.toString.equalsunion.geta&a=union.size-1 if .str.equals str += ,; str += p.data.toString; q = q.next; p = p.next; i = 0; Node w = list.head.next; while w .= null str += ,; str += w.d
7、ata.toString; w = w.next; return str + ; /以上为求并集过程;public String differenceSinglyList list Node p = this.head.next; String str = ; while p .= null Node q = list.head.next; int i = 0; while q .= null if .p.data.toString.equalsq.data.toString i+; if i = list.length if .str.equals str += ,; str += p.da
8、ta.toString; q = q.next; p = p.next; i = 0; return str + ; /以上为求差集过程;程序 3:import java.util.Scanner; public class MainClass public static void mainString args int a, b; Scanner cin = new ScannerSystem.in; System.out.print 请输入集合A 的元素(用英文逗号间隔): ; String a_string=cin.nextLine; String suma=a_string.split,; System.out.print 请输入集合B 的元素(用英文逗号间隔):; String b_string=cin.nextLine; String sumb=b_string.split,; SinglyList list1 = new SinglyListsuma; SinglyList list2 = new SinglyListsumb; System.out.println 集合 A 和集合 B 的交集为: +list1.addAlllist2; System.out.println 集合 A 和集合 B 的并集
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 医学26年:非糜烂性反流病诊疗 查房课件
- 上海工程技术大学《AutoCAD 工程制图》2025-2026学年第一学期期末试卷(B卷)
- 上海工商职业技术学院《安装工程结构与施工》2025-2026学年第一学期期末试卷(B卷)
- 小学生态平衡2025说课稿
- 自定主题活动记录表三说课稿2025年小学综合实践活动一年级下册浙科技版
- 第1课 丰收的歌谣说课稿2025学年初中音乐鄂教版2024七年级下册-鄂教版2024
- 4.1 电磁波的发现说课稿2025学年高中物理上海科教版选修1-1-沪教版2007
- 上饶卫生健康职业学院《AutoCAD 工程制图》2025-2026学年第一学期期末试卷(B卷)
- 上海音乐学院《安装工程技术》2025-2026学年第一学期期末试卷(B卷)
- 脑瘫患者皮肤护理及预防压疮
- 货运驾驶员安全管理制度
- 四川省省属事业单位考试《综合知识》复习大纲考试笔试高频考点题库附答案解析
- 2023年冯晓强策略班课堂笔记
- GB/T 14561-2019消火栓箱
- 生态环境规划-课件
- 态度在民航服务工作中的运用课件
- Unit4 写作课 A Funny Story教案-高中英语北师大版(2019)选择性必修第二册
- 果树学实验-主要果实类型与构造认识解答课件
- 山东省青岛市各县区乡镇行政村村庄村名居民村民委员会明细及行政区划代码
- 仁爱版初中英语单词汇总
- 人教版八年级下英语单词默写版与完整版
评论
0/150
提交评论