Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/65: Рейтинг темы: голосов - 65, средняя оценка - 4.82
34 / 34 / 21
Регистрация: 22.09.2013
Сообщений: 401

Перестановка элементов в списке

17.11.2015, 20:49. Показов 13856. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Ни когда не работал c Java. Нужно выполнить следующее задание.

Не используя вспомогательных объектов, переставить отрицательные элементы
данного списка в конец, а положительные - в начало этого списка.
Как я попытался сделать

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
/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
 
package javaapplication3;
 
import java.util.ArrayList;
import java.util.List;
 
/**
 *
 * @author pi214sz
 */
public class Main {
 
    /**
     * @param args the command line arguments
     */
    public static void main(String[] args) {
        // TODO code application logic here
        ArrayList<Integer> list = new ArrayList<Integer>();
        list.add(-5);
        list.add(5);
        list.add(3);
        list.add(-3);
        list.add(-2);
        list.add(2);
        list.add(1);
        list.add(-1);
        for(int i=0;i<list.size();i++)
        {
         int a;
         a = list.get(i);
         for (int j=0;j<list.size();j++)
         {
          int b;
          b = list.get(j);
          if (a>b)
          {
           list.add(j,b);
           list.add(i,a);
          }
         }
        }
        for(int i=0;i<list.size();i++)
        {
          System.out.print(list.get(i)+" ");
        }
    }
 
}
Но в ответ тишина. То есть, тупо ничего не выводится.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
17.11.2015, 20:49
Ответы с готовыми решениями:

Перестановка элементов массива
Помогите пожалуйста решить задачку. Есть число K = 5 Нужно отсортировать массив так, что всё что больше K было перед ним, а всё что...

Перестановка элементов массива
Переставить элементы массива так, чтобы сначала шли все отрицательные элементы массива, затем все нулевые элементы, затем все положительные...

Оставить в списке только первые вхождения одинаковых элементов
Дан список L, элементы которого являются действительными числами. Оставить в списке только первые вхождения одинаковых элементов. ...

3
53 / 53 / 39
Регистрация: 05.12.2010
Сообщений: 261
18.11.2015, 10:04
Лучший ответ Сообщение было отмечено Sluchayno как решение

Решение

Почитайте мануал - функция add(index, element) добавляет в массив элемент в место index, и смещает остальные элементы направо. Чтобы заменить элемент под индексом index, надо использовать set(index, element)
А так у вас зацикливается 2-й цикл, потому что size() у list каждый раз растет на +1.

Добавлено через 8 минут
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
import java.util.ArrayList;
 
public class Main {
 
    public static void main(String[] args) {
        // TODO code application logic here
        ArrayList<Integer> list = new ArrayList<>();
        list.add(-5);
        list.add(5);
        list.add(3);
        list.add(-3);
        list.add(-2);
        list.add(2);
        list.add(1);
        list.add(-1);
        int a, b;
        for(int i = 0; i < list.size(); i++) {
            for (int j = list.size()-1; j > i; j--) {
                a = list.get(i);
                b = list.get(j);
                if (a > b) {
                    list.set(j, a);
                    list.set(i, b);
                }
            }
        }
        for(int i=0;i<list.size();i++)
        {
            System.out.print(list.get(i)+" ");
        }
    }
}
Вывод:
Java
1
-5 -3 -2 -1 1 2 3 5
1
34 / 34 / 21
Регистрация: 22.09.2013
Сообщений: 401
20.11.2015, 23:36  [ТС]
Огромное спасибо. Я прочитал про set но вот сделать
Java
1
for (int j = list.size()-1; j > i; j--) {
ума не хватило ))
0
12 / 12 / 4
Регистрация: 04.08.2010
Сообщений: 80
21.11.2015, 16:36
В формулировке указано, что нельзя использовать доп. объекты(int a,b - это все-таки дополнительные "объекты") и так же не указано, что нужно сортировать список, по этому предлагаю такое решение в один проход цикла:

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
   
 public static void main(String[] args) {
 
        List<Integer> list = new ArrayList<>(Arrays.asList(-10, -5, 5, 3, -3, -2, 2, 1, -1, 5, 0));
 
        int len = list.size();                  // размер списка
        int i = 0;                              // текущий индекс
        int replace = 0;                        // кол-во перенесенных элементов
        while ( i < len - replace) {                  // выполняем пока текущий элемент не будет последним не обработанным элементом      
            if (list.get(i) < 0) {                      
                list.add(len - 1, list.remove(i));    // переносим отрицательный элемент в конец списка
                replace++;                            // увеличиваем кол-во перенеснных элементов 
            } else {
                i++;                                  // иначе переходим к след элементу
            }
        }
        System.out.println(list);
    }
Кстати, тут использован ArrayList, но советуют для таких случаев, где производится множество удалений из середины списка использовать LinkedList, но на практике ArrayList все же быстрее и пребует меньше памяти, по этому тут он.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.11.2015, 16:36
Помогаю со студенческими работами здесь

Перестановка элементов в списке
Функция перестановки местами соседних четных и нечетных элементов в заданном списке

Перестановка элементов в динамическом списке
Дан список из n целых чисел, a1,a2...an. Поменять местами первый из минимальных и последний из положительных элементов списка. Не...

Циклическая перестановка N следующих подряд элементов в списке
Напишите функцию, осуществляющую циклическую перестановку N следующих подряд элементов в списке. Например, при N=3 и исходном списке (a b c...

Определите предикат p(+U, +V, ?L) - истинный тогда и только тогда, когда L - список всех элементов, содержащихся либо в списке U, либо в списке V.
Здравствуйте, помогите пожалуйста решить задачу. Заранее благодарна) Определите предикат p(+U, +V, ?L) - истинный тогда и только...

Перестановка элементов
Уважаемые форумчане! Требуется: в каждой строке поменять местами первый элемент и максимальный по модулю в двумерном массиве!


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Киев стоит - украинская песня
zorxor 28.01.2026
wfWdiRqdTxc О Господи, Вечный, Ты . . . Я помоги, Бесконечный. . . Я прошу Ты. . . Я погибаю, спаси. . . Я прошу Тебя Вечный. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru