您的位置:

java对象数组排序,java对一个数组排序

本文目录一览:

java 数组顺序排列

首先,API里面写了: Sorts the specified array of ints into ascending numerical order.

就是这是个升序!

其次,你这个运行应该不会报错,输出的会是 数组地址,因为数组在java里面是一个对象,如果要看排序的结果,需要遍历下:

比如

for(int i:arr){

System.out.println(i);

}

java对象数组排序中如何让性别为女的排在前面

可以使用if判断的方法来将性别为女的排在前面,Java是一门面向对象的编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。

java 如何对对象进行排序

纠正几点错误:

首先TreeSet就是一个二叉树排序容器,由用户定义对象比较规则,然后接口回调进行排序,也就是说当对象在add到容器后实际上已经按照你定义的排序规则排序完毕了,所以你也没有必要再单独写一个排序方法。

如果你想单独写一个排序算法,传送TreeSet()这样已经排序完毕的容器当然是多此一举的。 你可以用List保存你的对象,这样容器保存的就是原始的对象集合(按add()的先后顺序排序),这样才能真正发挥排序方法的功能.

其次,你的冒泡排序算法是按照价格从小到大的,而你add对象的时候就是从小到大的,所以一直没有满足if(iArr[j].price iArr[j+1].price) { 这个条件,可以把号改成号,或者打乱add的顺序,这样就能看出效果。

另外从容器内取元素应该用循环,而不应该写死。你应该知道,所以程序我也没修改~

下面的程序在原作上面稍微修改了一下,自己可以比较一下区别

package cn.com.csuinfo.Mycollec;

import java.util.ArrayList;

import java.util.List;

public class TestMySort {

public void BubbleSort(ListCar list) {

Car c1;

Car c2;

Car c3;

Car c4;

c1 = list.get(0);// 将set中的元素一个个取出来,再存入Car数组中

c2 = list.get(1);

c3 = list.get(2);

c4 = list.get(3);

Car[] iArr = { c1, c2, c3, c4 }; // 数组中存放了Car类型的四个对象

Car tmp = null;

int len = list.size();

for (int i = 0; i len - 1; i++) {// 对数组中的对象按属性值price的大小进行排序

for (int j = 0; j len - 1 - i; j++) {

if (iArr[j].price iArr[j + 1].price) {

tmp = iArr[j];

iArr[j] = iArr[j + 1];

iArr[j + 1] = tmp;

System.out.println("change");// 测试之注意!:程序没执行到此来???

}

}

}

for (Car car : iArr) {

System.out.println(car);

}

}

public static void main(String[] args) {

ListCar list = new ArrayListCar();

Car car1 = new Car("Ford", 164000);

Car car2 = new Car("Honda", 286000);

Car car3 = new Car("Toyota", 410000);

Car car4 = new Car("Benz", 850000);

list.add(car1);

list.add(car2);

list.add(car3);

list.add(car4);

System.out.println("***********************“");

new TestMySort().BubbleSort(list);

}

}

在java编程中如何对数组进行排序,并输出排序后的数组及原数组下标值

java变成对数组进行排序可以使用ArraySort方法,保存源数组下标值可以存入map中,如下代码:

import java.util.ArrayList;

import java.util.Arrays;

import java.util.HashMap;

import java.util.List;

public class ceshi {

public static void main(String[] args) {

int n = 5;

int[] a = { 8, 5, 4, 6, 2, 1, 7, 9, 3 };

HashMap map = new HashMap();

for (int i = 0; i  a.length; i++) {

map.put(a[i], i); // 将值和下标存入Map

}

// 排列

List list = new ArrayList();

Arrays.sort(a); // 升序排列

for (int i = 0; i  a.length; i++) {

list.add(a[i]);

}

for (Object object : list) {

System.out.print(object + ",");

}

System.out.println();

// 查找原始下标

for (int i = 0; i  n; i++) {

System.out.print(map.get(a[i]) + ",");

}

}

}

运行结果如下:

JAVA 数组中的元素是对象,如何给对象排序

写那么麻烦干什么呢,看我的!

Book[] books = { new Book("j2me",12), new Book("j2se",5), new Book("j2ee",22) };

Arrays.sort (books, new ComparatorBook ()

{

    @Override

    public int compare ( Book o1, Book o2 )

    {

        if (o1.getPrice()   o2.getPrice() )

        {

            return 1;

        }

        else if (o1.getPrice()   o2.getPrice() )

        {

            return -1;

        }

        else

        {

            return 0;

        }

    }

});