如果你不想任務更加複雜,你真的應該創建一個類,說Job
,以存儲這些屬性,而不是使用String[]
。然後保持List<Job>
。
在Job
類中,應該執行equals()
和hashCode()
方法,根據category
進行比較。因此,類將是這樣的:
class Job {
private int id;
private String category;
private int no;
public Job(int id, String category, int no) {
this.id = id;
this.category = category;
this.no = no;
}
@Override
public boolean equals(Object obj) {
if (!(obj instanceof Job)) return false;
return category.equals(((Job)obj).category);
}
@Override
public int hashCode() {
return category.hashCode();
}
@Override
public String toString() {
return "[" + id + ", " + category + ", " + no + "]\n";
}
}
現在,你可以有一個List<Job>
:
Job s1= new Job(22,"Software",1);
Job s2= new Job(45,"Software",2);
Job s3= new Job(78, "Hardware", 3);
Job s4= new Job(48, "Software", 4);
Job s5= new Job(11, "Hardware", 5);
Job s6= new Job(91, "Service", 6);
Job s7 =new Job(95, "Service", 7);
Job s8 = new Job(93, "Software", 8);
List<Job> list=new ArrayList<Job>(Arrays.asList(s1, s2, s3, s4, s5, s6, s7, s8));
創建一個臨時ArrayList
,將存儲你的結果:
List<Job> contiguous = new ArrayList<Job>();
/* The boolean variable will be used to track whether the sequence till
now is contiguous or not */
/* Everytime we add a new unique job, a new contiguous sequence is started.
So, we will set this variable to `true` */
boolean isContiguousTillNow = false;
這裏的執行實際工作的循環:
for (Job job: list) {
if (contiguous.isEmpty()) {
/* First job added. Set 'isContiguousTillNow' to 'true' */
contiguous.add(job);
isContiguousTillNow = true;
} else if (isContiguousTillNow && contiguous.get(contiguous.size() - 1).equals(job)) {
/* The sequence has been contiguous till now, and the last job
added is equal to current job. Add the job. */
contiguous.add(job);
} else if (!contiguous.contains(job)) {
/* Sequence is either broken here, or was already broken */
/* But since the list doesn't already contains this job, add it,
and this starts a new contiguous sequence. So, set it to 'true' */
contiguous.add(job);
isContiguousTillNow = true;
} else {
/* ContigousSequence stops here. So, set it to 'false' */
isContiguousTillNow = false;
}
}
然後您的contiguous
列表將包含所需的結果。
當你說連續體時,你的意思是設置? –
不,它只是意味着我想要繼續行,沒有任何關係設置 – Tum
你的意思是連續的 –