1.给出一个Person类里面包含姓名、年龄、成绩,声明5个Person对象数组,要求对数组中的内容进行排序,排序规则如下:按成绩由高到低排序,如果成绩一样,按年龄由高到低排序。

本文介绍了一个Java类Person的构造函数使用方法,并演示了如何利用该类创建对象数组及通过冒泡排序算法按成绩和年龄对这些对象进行排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

重点:构造函数的使用的方法。

public class Person {

    //定义成员变量

    String name;
    int age;

    float score;

    //对象交换的过渡对象。

    Person temp;


    public Person(String n,int a,float s){//此处不能用name,age,score做参数,如果如此,可以在赋值时前加this.,代表调用此构造函数的成员变量
        name=n;
        age=a;
        score=s;
    }
    

    public void bubble(Person person[]){

//基于冒泡排序

        for(int i=0;i<person.length-1;i++){

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

                    if(person[j].score<=person[j+1].score){

//根据成绩交换位置

                            if(person[j].score<person[j+1].score){
                                    temp=person[j];
                                    person[j]=person[j+1];
                                    person[j+1]=temp;

                            }

//根据年龄交换位置

                            if(person[j].score==person[j+1].score){
                                if(person[j].age<person[j+1].age){
                                    temp=person[j];
                                    person[j]=person[j+1];
                                    person[j+1]=temp;
                                }
                            }
                    }
            }
        }
    }
    public String toString(Person person){
        return (person.name+" "+person.age+" "+person.score);
    }

}


package www.one.com;

import java.util.Scanner;

public class Demo {
    public static void main(String args[]){
        Person dy=new Person();
        Person person[]=new Person[5];
        person[0]=new Person("Roman",27,98);
        person[1]=new Person("Tic",28,98);
        person[2]=new Person("KK",23,100);
        person[3]=new Person("Jack",25,99);
        person[4]=new Person("Rose",28,98);

//调用排序方法

        dy.bubble(person);
        for(int i=0;i<person.length;i++)
            System.out.println(person[i].toString(person[i]));
    }
    
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值