-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathPowerSet.java
More file actions
112 lines (98 loc) · 3.15 KB
/
PowerSet.java
File metadata and controls
112 lines (98 loc) · 3.15 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
import java.util.ArrayList;
public class PowerSet {
public ArrayList list;
public PowerSet() {
// ваша реализация хранилища
list = new ArrayList();
}
public int size() {
// количество элементов в множестве
return list.size();
}
public void put(String value) {
// всегда срабатывает
if (!get(value)) {
list.add(value);
}
}
public boolean get(String value) {
// возвращает true если value имеется в множестве,
// иначе false
for (int i = 0; i < list.size(); i++) {
if (list.get(i).equals(value)) {
return true;
}
}
return false;
}
public boolean remove(String value) {
// возвращает true если value удалено
// иначе false
for (int i = 0; i < list.size(); i++) {
if (list.get(i).equals(value)) {
list.remove(i);
return true;
}
}
return false;
}
public void display() {
for (int i = 0; i < list.size(); i++) {
System.out.print(list.get(i) + " ");
}
System.out.println();
}
public PowerSet intersection(PowerSet set2) {
// пересечение текущего множества и set2
PowerSet set = new PowerSet();
for (int i = 0; i < list.size(); i++) {
if (set2.get((String) list.get(i))) {
set.put((String) list.get(i));
}
}
return set;
}
public ArrayList convert() {
ArrayList arrayList = new ArrayList();
for (int i = 0; i < list.size(); i++) {
arrayList.add(list.get(i));
}
return arrayList;
}
public PowerSet union(PowerSet set2) {
PowerSet unionSet = new PowerSet();
// объединение текущего множества и set2
for (int i = 0; i < list.size(); i++) {
unionSet.put((String) list.get(i));
}
for (int i = 0; i < set2.convert().size(); i++) {
unionSet.put((String) set2.convert().get(i));
}
return unionSet;
}
public PowerSet difference(PowerSet set2) {
// разница текущего множества и set2
PowerSet set = new PowerSet();
for (int i = 0; i < list.size(); i++) {
if (!set2.get((String) list.get(i))) {
set.put((String) list.get(i));
}
}
return set;
}
public boolean isSubset(PowerSet set2) {
// возвращает true, если set2 есть
// подмножество текущего множества,
// иначе false
int counter = 0;
if (set2.size() <= list.size()) {
for (int i = 0; i < list.size(); i++) {
if (set2.get((String) list.get(i))) {
counter++;
}
}
return counter == set2.size();
}
return false;
}
}