我正在写一个叫做HighSchool的类,它有一个名为大学的弦乐阵列。我的目标是创建一个名为addCollege(String c)的方法,该方法接受字符串,检查列表,然后只要字符串已经不在列表中,就按正确的字母顺序排列。这是迄今为止我所做的,但它只是列表的第一部分。我也试图做这个没有collections.sort。将字符串添加到arraylist按顺序
public void addCollege(String c){
String s="";
for(int i=0; i<=universities.size()-1; i++){
if(c.equals(universities.get(i)))
return;
}
universities.add(c);
for(int p=1; p<=universities.size()-1; p++)
if(universities.get(p-1).compareTo(universities.get(p))>0){
s=universities.get(p);
universities.set(p, universities.get(p-1));
universities.set(p-1, s);
}
}
这是测试仪的内容。大部分是不相关的我的问题:
public class schoolTester {
public static void main(String[] args) {
School s=new School(1000, "600 Pine Lane", "Pines School", "Bob Smith");
int[] x={4,4,4,4,4,4};
Elementary e=new Elementary(2000, "601 Pine Lane", "Everglades", "Bobby Smith", x);
ArrayList<String>uni=new ArrayList<String>();
uni.add("Harvard");
uni.add("MIT");
uni.add("Georgia Tech");
uni.add("UCF");
HighSchool h=new HighSchool(4000, "602 Pine Lane", "hi-school", "bob smith", uni);
h.addCollege("Berkely");
h.addCollege("Miami");
h.addCollege("FSU");
h.addCollege("FGCU");
System.out.println(h.getColleges());
h.addCollege("FSU");
System.out.println(h.getColleges());
}
}
我假设这是学校,排除List.Contains()以及? 有一件事我会开始 - 比较名称时,添加一个toUpper()两个 - 或equalsIgnoreCase(),以防万一他们在不同情况下进来 – Neverwork2123 2015-02-10 04:51:51
好主意。我注意到java在处理不同情况时可能会感到困惑。 – jeff98 2015-02-10 05:03:12
而不工作的原因是,你试图通过阵列只使用一个扫描排序 假设你不想递归做它,添加一段时间 flag = 1; while(flag == 1){ 您的排序循环在这里 如果更改设置标志为1,否则为0} – Neverwork2123 2015-02-10 05:05:10