Форум программистов, компьютерный форум, киберфорум
Java для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/21: Рейтинг темы: голосов - 21, средняя оценка - 4.62
34 / 34 / 5
Регистрация: 25.02.2013
Сообщений: 221

Сортировка объектов в массиве на основе параметров

13.10.2013, 22:04. Показов 4511. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Имеем некий класс Product. По заданию можно использовать только массивы. Нужна сортировка по различным параметрам:
Java
1
2
3
4
5
6
7
//примерный класс
public class Product {
    private String name;
    private String brand;
    private double weight;
//далее геттеры, сеттеры, конструкторы и т.д.
}
Т.е. пользователь может выбрать сортировку по имени, или по весу ну и т.п. Используя Set можно как параметр передать нужный нам компаратор, а как быть с массивами?

Добавлено через 20 минут
Создать отдельно классы имплементирующие компаратор и передать в качестве параметров Arrays.sort(). как вариант. Какие способы ещё есть?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.10.2013, 22:04
Ответы с готовыми решениями:

Пересечение героя и платформы на основе расчета параметров прямоугольников
Ситуация такова. Есть платформа. Есть анимированый спрайт, который изначально появляется выше платформы (столкновений между ними нет). Есть...

Сохранение параметров объектов
У меня для моей программы при закрытии второй формы надо как то сделать так, что бы при следующем открытии все параметры объектов этой...

Создание дерева на основе свойств объектов
Добрый день! Прошу помощи! List<LeafObject> Set; class LeafObject { public DateTime Date { get; set; } ...

4
 Аватар для exiqa
487 / 333 / 71
Регистрация: 24.12.2011
Сообщений: 591
13.10.2013, 22:06
зачем вам еще способы?
0
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
13.10.2013, 22:06
Цитата Сообщение от Recreate Посмотреть сообщение
Какие способы ещё есть?
Сортировать вручную.
1
34 / 34 / 5
Регистрация: 25.02.2013
Сообщений: 221
13.10.2013, 23:10  [ТС]
Цитата Сообщение от exiqa Посмотреть сообщение
зачем вам еще способы?
для общего развития. я новичок поэтому и интересуюсь
0
Модератор
Эксперт PythonЭксперт JavaЭксперт CЭксперт С++
 Аватар для easybudda
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,973
13.10.2013, 23:55
Цитата Сообщение от Recreate Посмотреть сообщение
Создать отдельно классы имплементирующие компаратор и передать в качестве параметров Arrays.sort()
Ну да, "руками" сортировки писать разве, что для саморазвития полезно...
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
import java.util.*;
 
class Person {
    private String name;
    private Integer growth;
    private Double weight;
    
    Person(String n, int g, double w) {
        name = n;
        growth = g;
        weight = w;
    }
    
    public String getName() {
        return name;
    }
    
    public int getGrowth() {
        return growth;
    }
    
    public double getWeight() {
        return weight;
    }
    
    @Override
    public String toString() {
        return name + " " + growth + " " + weight;
    }
}
 
public class SortExamples {
    public static void main(String [] args) {
        Person [] persons = new Person [ 3 ];
        persons[0] = new Person("Petrov", 175, 91.5);
        persons[1] = new Person("Sidorov", 180, 100);
        persons[2] = new Person("Ivanov", 185, 85.5);
        
        System.out.println("Unsorted:");
        for ( Person p : persons )
            System.out.println(p);
        
        Arrays.sort(persons, new Comparator<Person> () {
            public int compare(Person a, Person b) {
                return a.getName().compareTo(b.getName());
            }
        });
        System.out.println("\nSorted by name:");
        for ( Person p : persons )
            System.out.println(p);
            
        Arrays.sort(persons, new Comparator<Person> () {
            public int compare(Person a, Person b) {
                return a.getGrowth() - b.getGrowth();
            }
        });
        System.out.println("\nSorted by growth:");
        for ( Person p : persons )
            System.out.println(p);
        
        Arrays.sort(persons, new Comparator<Person> () {
            public int compare(Person a, Person b) {
                double dif = a.getWeight() - b.getWeight();
                return ( dif < 0.0 ) ? -1 : ( dif > 0.0 ) ? 1 : 0;
            }
        });
        System.out.println("\nSorted by weight:");
        for ( Person p : persons )
            System.out.println(p);
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.10.2013, 23:55
Помогаю со студенческими работами здесь

Создание объектов на основе уже существующих
Добрый день! Есть список объектов List&lt;classA&gt; lst = new List&lt;classA&gt;(); В котором хранятся список его наследников с со своими...

Рандомное генерирование параметров объектов
Пишу игрушку..создал класс Rocks namespace StarTrack { class Rocks { public Texture2D RockTexture; ...

Сравнение объектов типовых параметров
Как сравнить объекты типовых параметров? Например:class Test&lt;K&gt; { private K a, b; public Test(K x, K y) { a = x;...

Сохранение динамических объектов и их параметров
В общем такая ситуация. Создаю динамические объекты, присваиваю процедуры, чтобы они двигались на форме. Как сохранить эти динамические...

Генерация объектов (например: ImageButton) на основе запроса БД
Как сделать слайдер из ImageButton(или чего то подобного), которые сами генерировались бы на основе запроса БД? Можно и без слайдера. ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru