Форум программистов, компьютерный форум, киберфорум
Java для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
0 / 0 / 0
Регистрация: 28.05.2021
Сообщений: 6

Массив: Создать новый двумерный массив, состоящий из ненулевых столбцов и строк переданного двумерного массива

25.03.2022, 00:53. Показов 1452. Ответов 7

Студворк — интернет-сервис помощи студентам
Создать новый двумерный массив, состоящий из ненулевых столбцов и строк переданного двумерного массива. (Нулевая строка или столбец – строка или столбец, содержащая одни нулевые элементы.)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.03.2022, 00:53
Ответы с готовыми решениями:

Дан двумерный массив А, состоящий из N строк и M столбцов. Удалить столбец, содержащий минимальный элемент массива некратный 4
Дан двумерный массив А, состоящий из N строк и M столбцов. Удалить столбец, содержащий минимальный элемент массива некратный 4 Нужен...

Сформируйте двумерный массив, состоящий из 5 строк и 3 столбцов
Сформируйте двумерный массив, состоящий из 5 строк и 3 столбцов по правилу a=i-j*j, и выведите его на экран. Вычислите сумму квадратов...

Сформируйте двумерный массив, состоящий из 3 строк и 6 столбцов по правилу a[i,j]=2i-j
Сформируйте двумерный массив, состоящий из 3 строк и 6 столбцов по правилу a=2i-j Язык С

7
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
25.03.2022, 10:11
найди номера столбцов и строк, содержащих одни нули
зная количество таких строк и стобцов можно вычислить размер нового массива (математика 3 класс)
дальше просто перебираешь все элементы, если номер строки или столбца равен одному из найденных на первом шаге - пропускаем элемент
0
0 / 0 / 0
Регистрация: 28.05.2021
Сообщений: 6
25.03.2022, 10:58  [ТС]
Можешь код кинуть как это реализовано быть должно
0
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
25.03.2022, 11:15
может ты поднапряжешься и напишешь его сам?
0
0 / 0 / 0
Регистрация: 28.05.2021
Сообщений: 6
25.03.2022, 11:31  [ТС]
Логику я понимаю, но с реализацией проблемы, у меня удаляются только нулевые столбцы, а со строками возникают проблемы

Добавлено через 2 минуты
Точнее со столбцами как раз проблемы

Java
1
2
3
4
5
6
7
8
private static int [][] DelEmptyRow2DArray(int[][] arr) {
        ArrayList<int[]> list = new ArrayList<int[]>();
        for (int[] str : arr) {
            if (str[0]+str[1] != 0)
                list.add(str);
        }
        return list.toArray(new int[0][0]);
    }
вот код удаления строк
0
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
25.03.2022, 14:42
я тебе по пунктам расписал, что надо делать
начни с метода, который возвращает true, если в столбце содержаться только нули
0
0 / 0 / 0
Регистрация: 25.11.2022
Сообщений: 1
25.11.2022, 21:47
romanys, Ты эту задачу не сделал? Можешь решение скинуть?
0
8 / 7 / 1
Регистрация: 10.04.2021
Сообщений: 20
26.11.2022, 23:28
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
72
73
74
75
76
77
78
79
80
81
82
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
 
public class TwoDArray {
    public static void main(String[] args) {
        ArrayList<ArrayList<Integer>> originalArray = new ArrayList<>();
        ArrayList<ArrayList<Integer>> transposedArray;
 
        try (BufferedReader reader = new BufferedReader(new FileReader("src/main/resources/matrix"))) {
            String line = reader.readLine();
 
            // Read array from a file
            while (line != null) {
                System.out.println(line);
                ArrayList<Integer> lineToAdd = new ArrayList<>();
                Arrays
                        .stream(line.split(" "))
                        .mapToInt(Integer::parseInt)
                        .forEach(lineToAdd::add);
                originalArray.add(lineToAdd);
                line = reader.readLine();
            }
 
            // check that the file contains rows of the same length
            HashSet<Integer> sizes = new HashSet<>();
            originalArray
                    .forEach(a -> sizes.add(a.size()));
 
            if (sizes.size() > 1) {
                System.out.println("Rows in the array are of different lengths");
                return;
            }
 
            // remove zero-rows and transpose the array
            transposedArray = transpose(removeZeroRows(originalArray));
 
            // remove zero-rows from the transposed array and transpose it back
            ArrayList<ArrayList<Integer>> finalArray = transpose(removeZeroRows(transposedArray));
            System.out.println("Final array: " + finalArray);
 
        } catch (IOException e) {
            System.out.println("File not found");
        }
    }
 
    // define if the row is a zero-row
    public static boolean isZeroRow(ArrayList<Integer> row) {
        return row
                .stream().noneMatch(i -> i != 0);
    }
 
    // create the resulting array. add only non-zero rows to the resulting array
    public static ArrayList<ArrayList<Integer>> removeZeroRows(ArrayList<ArrayList<Integer>> array) {
        ArrayList<ArrayList<Integer>> newArray = new ArrayList<>();
        array
                .stream().filter(row -> !isZeroRow(row))
                .forEach(newArray::add);
        if (newArray.size() == 0) {
            System.out.println("All rows in the array are zero-rows");
            System.exit(1);
        }
        return newArray;
    }
 
    // transpose the array. columns become rows in the new array
    public static ArrayList<ArrayList<Integer>> transpose(ArrayList<ArrayList<Integer>> array) {
        ArrayList<ArrayList<Integer>> result = new ArrayList<>();
 
        for (int j = 0; j < array.get(0).size(); j++) {
            ArrayList<Integer> colToAdd = new ArrayList<>();
            for (int i = 0; i < array.size(); i++) {
                colToAdd.add(array.get(i).get(j));
            }
            result.add(colToAdd);
        }
        return result;
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.11.2022, 23:28
Помогаю со студенческими работами здесь

Создать новый массив, исключив из переданного массива совпадающие столбцы
Не понимаю как написать. Задача: Создать новый двумерный массив, исключив из переданного массива совпадающие столбцы. (Совпадающие...

Задан двумерный массив, состоящий из N строк и M столбцов (N, M<10). Написать программу определения суммы з
Задан двумерный массив, состоящий из N строк и M столбцов (N, M&lt;10). Написать программу определения суммы значений элементов,...

Сформировать двумерный массив, состоящий из 4 строк и 4 столбцов по правилу m[ij]=i*j-3 и выведите его на экран. Вычисли
помогите пожалуйста, не могу понять как решить Сформировать двумерный массив, состоящий из 4 строк и 4 столбцов по правилу m=i*j-3 и...

Дан двумерный массив, содержащий 14 строк и 15 столбцов. Элементами массива являются целые числа. Упорядочить массив
Как решить в C# Windows Forms? В консольной не надо)

Дан двумерный массив А, состоящий из N строк и M столбцов. Отсортировать элементы первой строки улучшенным методом пузырька
Дан двумерный массив А, состоящий из N строк и M столбцов. Отсортировать элементы первой строки улучшенным методом пузырька. Нужна...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru