1. 程式人生 > >程式填空:根據給出的main類設計一個Student類(基礎題型)

程式填空:根據給出的main類設計一個Student類(基礎題型)

必備知識點:
1.println(物件)則直接呼叫了物件所屬類中重寫的toString方法,如果沒有重寫則直接呼叫Object中的原始toString方法:

	//@Override 的作用是:
	//如果想重寫父類的方法,
	//比如toString()方法的話,
	//在方法前面加上@Override
	//系統可以幫你檢查方法的正確性。
	//重寫toString方法,沒有形參
	@Override
	public String toString() {
		return "no="+this.no+"&name="+this.name;
	}

2.重寫equals方法:

	//重寫equals方法,有形參
	@Override
	public boolean equals(Object o) {
		if (o==null) return false;//如果o根本不存在
		else {//存在
			boolean result=false;
			if (o instanceof Student) {//判斷是否為子類或本類物件
				Student otherstu=(Student)o;//是則轉化為Student類
				if (this.no==otherstu.no)//比較no
					result=true;
			}
			return result;
		}
	}

3.重寫compareTo方法:()

//java中所有類的父類都是Object類,Student的父類也是Object
//所以在Student類中可以不用宣告extend,Object裡面的方法可以直接被Student重寫
//equals和toString方法
//但是因為compareto方法是介面comparable的所以要先宣告介面comparable再重寫他的compareTo方法
	//實現comparable介面中的compareto方法
	@Override
	public int compareTo(Object arg0) {
		//第一步先轉換為Student型別
		Student otherstu=(Student)arg0;
		if (this.no<otherstu.no)return -1;
		else if (this.no>otherstu.no)return 1;
		else return 0;
		//小的往上走位置-1,大的往下走+1,相等的位置保持不變
		//按照首字母降序排列的話就將1和-1倒過來
	}

題目:
要求:根據Main類中main方法中的程式碼,設計滿足要求的Student(學生)類:1)包含屬性:int no(學號)、String name(姓名);2)滿足Main類中main方法程式碼的說明要求。 Main類中main方法程式碼的說明:1)首先,從鍵盤接收形如“3 cuizhenyu 2 tiangang 1 dingchangqing 4 zhangfeng”的字串,該字串中包含了4個學生的學號和姓名(各學生以及學生的學號和姓名之間都用一個空格分隔,姓名中只包含英文字母),然後將該字串內容中的前3個學生的學號及其姓名放到到Student陣列stus中;2)將stus中的3個Student放入到HashSet stuSet中(注意:如果學生的學號相同,則認為是相同物件,不放入stuSet中);3)將第4個學生物件放入到stuSet中,如果第4個學生物件的學號與stuSet中已有學生物件的學號相同則不能放入。然後,打印出當前stuSet中學生物件的個數;4)用Arrays.sort方法對陣列stus按照學生姓名的字母順序排序(先比較首字母,首字母相同的比較第二個字母,以此類推),輸出排序後的stus中3個學生物件的內容,每個學生物件的輸出格式為“no=XX&name=YY”。

main類程式碼:

import java.util.Arrays;
import java.util.HashSet;
import java.util.Scanner;
import java.lang.*;
public class Main{
	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
		Student[] stus = new Student[3];

		for(int i=0;i<3;i++){
			int no = scan.nextInt();
			String name = scan.next();
			Student s = new Student(no,name);
			stus[i] =s;
		}
		//將stus中的3個學生物件,放入到HashSet中
		HashSet<Student> stuSet = new HashSet<Student>();
		for(Student s: stus){//s相當於i
			stuSet.add(s);
		}
		//要放入的第4個Student
		Student fourth = new Student(scan.nextInt(),scan.next());
		stuSet.add(fourth);//如果fourth的學號(no)與stuSet中的已有學生的no重複則無法放入
		System.out.println(stuSet.size());//第一次輸出——4
		
		Arrays.sort(stus);//對stus中的3個原有物件,按照姓名首字元有小到大排序
		//前提是必須實現了comparable介面
		for(int i=0;i<stus.length;i++){//排序後的輸出
			System.out.println(stus[i]);//輸出的格式為:no=XX&name=YY
		}
		
		scan.close();
	}
}

答案:

//java中所有類的父類都是Object類,Student的父類也是Object
//所以在Student類中可以不用宣告extend,Object裡面的方法可以直接被Student重寫
//equals和toString方法
//但是因為compareto方法是介面comparable的所以要先宣告介面comparable再重寫他的compareTo方法
class Student implements Comparable{
	//介面一般首字母大寫如Comparable和Collection List

	private int no;
	private String name;
	
	public Student(int no, String name) {
		this.name=name;
		this.no=no;
	}
	//toString和equals方法都是object類本來就有的
	
	//重寫toString方法,沒有形參
	@Override
	public String toString() {
		return "no="+this.no+"&name="+this.name;
	}
	//重寫equals方法,有形參
	@Override
	public boolean equals(Object o) {
		if (o==null) return false;//如果o根本不存在
		else {//存在
			boolean result=false;
			if (o instanceof Student) {//判斷是否為子類或本類物件
				Student otherstu=(Student)o;//是則轉化為Student類
				if (this.no==otherstu.no)//比較no
					result=true;
			}
			return result;
		}
	}
	//實現comparable介面中的compareto方法
	@Override
	//@Override 的作用是:
	//如果想重寫父類的方法,
	//比如toString()方法的話,
	//在方法前面加上@Override
	//系統可以幫你檢查方法的正確性。
	public int compareTo(Object arg0) {
		//第一步先轉換為Student型別
		Student otherstu=(Student)arg0;
		if (this.no<otherstu.no)return -1;
		else if (this.no>otherstu.no)return 1;
		else return 0;
		//小的往上走位置-1,大的往下走+1,相等的位置保持不變
		//按照首字母降序排列的話就將1和-1倒過來
	}
}

遇到的問題
當在環境中執行程式發現出現錯誤提示:
錯誤: 在類中找不到 main 方法, 請將 main 方法定義為:public static void main(String[] args)否則 JavaFX 應用程式類必須擴充套件javafx.ap
解決詳見https://blog.csdn.net/liu1340308350/article/details/80746671