gpt4 book ai didi

java - 字符串的冒泡排序。 java

转载 作者:行者123 更新时间:2023-12-02 13:15:34 25 4
gpt4 key购买 nike

这是我第一次为字符串编写冒泡排序,显然我遇到了很多错误,并且程序无法运行。我不知道如何解决它。我的代码是:

import java.util.*;
public class SortingRecord{
public static void main(String args[]){
Scanner kb = new Scanner(System.in);
System.out.println("How many people?");
int n = Integer.parseInt(kb.nextLine());
Record[] records = new Record[n];
for(int i = 0; i<n; i++){
System.out.println("Inputting record["+i+"]:");
System.out.print("Please input <First Name>:");
String firstName = kb.nextLine();
System.out.println("Please input <Last Name>:");
String lastName = kb.nextLine();
records[i] = new Record(firstName, lastName);
}
sort(records);
System.out.println("----------------");
System.out.println("Print name in dictinary order:");
for(int i = 0; i < n ; i++)
System.out.println();
}

public static void sort(Record[] records){
if (records == null || records.length <= 1) return;
int n = records.length;

for(int i = 0; i< records.length ; i++){
for(int j = i+1 ; j< records.length; j++){

找不到符号方法compareTo(Record)。

                     if(records[j] .compareTo(records[i]) < 0){

它说Record无法转换为java.lang.String

                     String temp = records[i];
records[i] = records[j];
records[j] = temp;
}
}
System.out.println(records[i]);

}
}

}

class Record{
public String firstName = "";
public String lastName = "";
public Record(String firstName, String lastName){
this.firstName = firstName;
this.lastName = lastName;
}
}

最佳答案

让我们看一下明显的错误:

if (records[j].compareTo(records[i]) < 0) {

Record 不提供任何 compareTo 方法,因此您无法调用它 - 它不存在。

下一个错误:

String temp = records[i];

是因为Record不是String类型,所以无法赋值,显而易见的解决方案是使用Record来代替,类似...

Record temp = records[i];
records[i] = records[j];
records[j] = temp;

好的,但是我们如何解决 compareTo 问题呢?这比听起来更复杂,当您实现 Comparable 接口(interface)(或者直接实现compareTo 方法)时,我不会选择这条路。为什么?因为您可能想要更改记录排序的方式,而实现该方法会将您锁定在单个用例中。

相反,我会使用传递到方法中的 Comparator 来进行实际比较,为调用者提供更改比较实际工作方式的灵 active

public static void sort(Record[] records, Comparator<Record> comparator) {
if (records == null || records.length <= 1) {
return;
}
int n = records.length;

for (int i = 0; i < records.length; i++) {
for (int j = i + 1; j < records.length; j++) {
if (comparator.compare(records[j], records[i]) < 0) {
Record temp = records[i];
records[i] = records[j];
records[j] = temp;
}
}
System.out.println(records[i]);

}
}

然后你可以做类似的事情......

sort(records, new Comparator<Record>() {
@Override
public int compare(Record o1, Record o2) {
return o1.firstName.compareTo(o2.firstName);
}
});

sort(records, new Comparator<Record>() {
@Override
public int compare(Record o1, Record o2) {
return o1.lastName.compareTo(o2.lastName);
}
});

甚至

sort(records, new Comparator<Record>() {
@Override
public int compare(Record o1, Record o2) {
int compare = o1.firstName.compareTo(o2.firstName);
if (compare == 0) {
compare = o1.lastName.compareTo(o2.lastName);
}
return compare;
}
});

或者您可能需要什么其他组合来满足您的要求

我建议看看 Comparator了解更多详情

我还应该指出,您可以使用Collections来存储对象,但您需要将其转换为List而不是数组...

Collections.sort(Arrays.asList(records), new Comparator<Record>() {...});

the program fail to output the name in dictionary order;(

对我来说效果很好...

import java.util.Comparator;

public class Test {

public static void main(String[] args) {
new Test();
}

public Test() {
Record[] records = new Record[] {
new Record("B", "B"),
new Record("C", "B"),
new Record("D", "B"),
new Record("A", "E"),
new Record("A", "B"),
new Record("A", "C"),
new Record("A", "A"),
};
sort(records, new Comparator<Record>() {
@Override
public int compare(Record o1, Record o2) {
int compare = o1.firstName.compareTo(o2.firstName);
if (compare == 0) {
compare = o1.lastName.compareTo(o2.lastName);
}
return compare;
}
});

for (Record record : records) {
System.out.println(record);
}
}

public static void sort(Record[] records, Comparator<Record> comparator) {
if (records == null || records.length <= 1) {
return;
}

for (int i = 0; i < records.length; i++) {
for (int j = i + 1; j < records.length; j++) {
if (comparator.compare(records[j], records[i]) < 0) {
Record temp = records[i];
records[i] = records[j];
records[j] = temp;
}
}
}
}

class Record {

public String firstName = "";
public String lastName = "";

public Record(String firstName, String lastName) {
this.firstName = firstName;
this.lastName = lastName;
}

@Override
public String toString() {
return firstName + " " + lastName;
}


}
}

输出

A A
A B
A C
A E
B B
C B
D B

关于java - 字符串的冒泡排序。 java ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43775875/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com