Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
 Аватар для Serg22
107 / 107 / 58
Регистрация: 04.03.2013
Сообщений: 479

Обьединить два упорядоченных arraylist'a так, чтобы результирующий остался упорядоченным

02.11.2014, 17:36. Показов 2081. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Даны два массива A и B, состоящие из n элементов каждый, элементы которых упорядочены по убыванию. Объединить эти массивы так, чтобы результирующий массив остался упорядоченным

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
 class AL{
    private int size1, size2;
    public ArrayList<Integer> a1, a2;
    AL(int a, int b){
    size1=a;
    size2=b;
       a1 = new ArrayList<>();
              a2 = new ArrayList<>();
           
              for(int i = 0; i < size1  ; i++){
              a1.add((int)(Math.random()*100));
              }
              for(int i = 0; i < size2  ; i++){
              a2.add((int)(Math.random()*100));
              }
    }
..........
 array=new AL(n,m);// размерность
Организовал через ArrayList, заполнил случайными значениями, отсортировал.
Теперь нужно в 1й массив добавлять эл-ты из второго, таким образом что бы первый остался отсортированым.




Помогите с циклом, пожалуйста)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
02.11.2014, 17:36
Ответы с готовыми решениями:

Объединить массивы так, чтобы результирующий массив С (размера 10) остался упорядоченным по возрастанию
6.Даны два массива А и В размера 5, элементы которых упорядочены по возрастанию. Объединить эти массивы так, чтобы результирующий массив С...

Объединить два упорядоченных массива так, чтобы результирующий массив остался упорядоченным
Даны два массива a и b размера n, элементы которых упорядочены по возрастанию. Объединить эти массивы так, чтобы результирующий массив...

Объединить два массивы так, чтобы результирующий массив остался упорядоченным по возрастанию
Пожалуйста, помогите решить задачу, желательно с объяснениями! Даны два массива A и B размера 5, элементы которых упорядочены по...

3
Эксперт 1С
 Аватар для Tklwegsd
845 / 608 / 211
Регистрация: 24.07.2013
Сообщений: 2,102
02.11.2014, 18:30
На массивах:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
public static int[] mergeSort(int[] array1, int[] array2) {
        
        int   length = array1.length + array2.length;
        int[] array  = new int[length];
        
        int i = 0;
        int j = 0;
        
        for (int k = 0; k < length; k++) {
            if (i >= array1.length) {
                array[k] = array2[j++];
            } else if (j >= array2.length) {
                array[k] = array1[i++];
            } else if (array1[i] >= array2[j]) {
                array[k] = array1[i++];
            } else {
                array[k] = array2[j++];
            }
        }
        
        return array;
        
    }
0
любитель покушать
 Аватар для Севак
687 / 641 / 248
Регистрация: 25.09.2011
Сообщений: 1,313
02.11.2014, 18:34
Serg22,
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
import java.util.*;
 
public class Test {
    public static void main(String[] args) {
        List<Integer> a = new ArrayList<>();
        List<Integer> b = new ArrayList<>();
 
        for (int i = 0; i < 5; i++) {
            a.add((int) (Math.random() * 100));
        }
 
        for (int i = 0; i < 6; i++) {
            b.add((int) (Math.random() * 100));
        }
 
        Comparator<Integer> comparator = (o1, o2) -> -Integer.compare(o1, o2);
        Collections.sort(a, comparator);
        Collections.sort(b, comparator);
 
 
        List<Integer> res = new ArrayList<>();
        int i = 0;
        int j = 0;
        while(i < a.size() && j < b.size()) {
            if(a.get(i) > b.get(j)) {
                res.add(a.get(i));
                ++i;
            } else {
                res.add(b.get(j));
                ++j;
            }
        }
 
        while(i < a.size()) {
            res.add(a.get(i));
            ++i;
        }
 
        while(j < b.size()) {
            res.add(b.get(j));
            ++j;
        }
 
        System.out.println(a);
        System.out.println(b);
        System.out.println(res);
    }
}
1
 Аватар для Serg22
107 / 107 / 58
Регистрация: 04.03.2013
Сообщений: 479
02.11.2014, 22:47  [ТС]
Большое спасибо )
Упорядочивание по убыванию изменил немного:
Java
1
Collections.sort(a,Collections.reverseOrder());
ЗЫ: А можно изменить что бы общее кол-во используемых массивов осталось два? т.е эл-ты добавлялись скажем в первый массив из второго?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.11.2014, 22:47
Помогаю со студенческими работами здесь

Объединить массивы так, чтобы результирующий остался упорядоченным по убыванию
Даны три целочисленных массива A, B и C размера Na, Nb, Nc соответственно, элементы которых упорядочены по убыванию. Объединить эти массивы...

Объединить массивы так, чтобы результирующий массив C остался упорядоченным по возрастанию
1.Даны два массива A и B, элементы которых упорядочены по возрастанию. Объединить эти массивы так, чтобы результирующий массив C остался...

Объединить массивы так, чтобы результирующий массив остался упорядоченным по возрастанию
Даны два массива A и B, элементы которых упорядочены по возрастанию. Объединить эти массивы так, чтобы результирующий массив C остался...

Объединить массивы так, чтобы результирующий массив C остался упорядоченным по возрастанию
С помощью массива. Даны два массива A и B размера 5, элементы которых упорядочены по возрастанию. Объединить эти массивы так, чтобы...

Объединить массивы так, чтобы результирующий массив остался упорядоченным по убыванию
Даны три целочисленных массива A, B и C размера NA, NB, NC соответственно, элементы которых упорядочены по убыванию. Объединить эти массивы...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru