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

Ленточная матрица

11.09.2022, 12:24. Показов 1575. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет, как осуществить это задание? Нужно диагонали матрицы записать в ряд. Выглядит следующим образом

Исходная:

5 8 2 0 0 0
7 9 0 8 0 0
0 4 0 2 5 0
0 0 1 3 9 1
0 0 0 0 4 3
0 0 0 0 6 0

Результат:
0 5 8 2
7 9 0 8
4 0 2 5
1 3 9 1
0 4 3 0
6 0 0 0
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.09.2022, 12:24
Ответы с готовыми решениями:

Ленточная матрица
Квадратную матрицу называют ленточной шириной d, если все ее элементы, расположенные ниже d-ой поддиагонали и выше d-ой наддиагонали, равны...

Ленточная матрица и вектор
Нужно написать программу, которая умножит квадратную ленточную несимметричную атрицу на вектор без выделения диагонали. В файле задается...

Как создать Разряженная Ленточная матрица
Как создать разряженную ленточную матрицу, так что бы мы вводили только Например 1, 2, 3, и получали: 100 020 030 я нашел...

8
4 / 3 / 1
Регистрация: 07.11.2019
Сообщений: 330
11.09.2022, 13:05  [ТС]
Вот скриншот, тут понятнее
Миниатюры
Ленточная матрица  
0
4 / 3 / 1
Регистрация: 07.11.2019
Сообщений: 330
11.09.2022, 14:26  [ТС]
help
0
4 / 3 / 1
Регистрация: 07.11.2019
Сообщений: 330
11.09.2022, 15:14  [ТС]
Java
1
2
3
4
5
6
7
8
        for (int r = M-1; r >= 0; r--)
        {
            for (int j = 0, i = r; i >= 0 && j < N; i--, j++) {
                System.out.print(mat[i][j] + " ");
            }
 
            System.out.print(System.lineSeparator());
        }
Есть такое, только мне нужно диагональ в другую сторону брать как на скриншоте
Изображения
 
0
4 / 3 / 1
Регистрация: 07.11.2019
Сообщений: 330
11.09.2022, 16:23  [ТС]
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
        int M = mat.length;
        int N = mat[0].length;
        
        for (int r = M - 1; r >= 0; r--) {
            for (int i = r, j = 0; j >= 0 && i < M; i++, j++) {
                System.out.print(mat[i][j] + " ");
            }
            System.out.print(System.lineSeparator());
        }
        for (int c = N - 1; c >= 0; c--) {
            for (int i = 0, j = c; j < N && i >= 0; i++, j++) {
                System.out.print(mat[i][j] + " ");
            }
            System.out.print(System.lineSeparator());
        }
    }
Пока что так, получилось взять диагональ в правильном направлении, только не знаю как теперь эти два треугольника соеденить, если бы получилось, думаю попробовать транспонировать матрицу
Миниатюры
Ленточная матрица  
0
4 / 3 / 1
Регистрация: 07.11.2019
Сообщений: 330
11.09.2022, 17:12  [ТС]
Я сдаюсь, надеюсь кто нибудь ответит, все очень запутано
0
Заблокирован
11.09.2022, 17:49
исходные матрицы всегда квадратные? нулевые диагонали не интересны?
0
4 / 3 / 1
Регистрация: 07.11.2019
Сообщений: 330
11.09.2022, 18:19  [ТС]
CoderPC, В моем случае матрица квадратная, если говорить о нулевых диагоналях, в моем условии пишет:
"Идея алгоритма заключается в использовании для хранения исходной матрицы массива размером m x n, в котором порядочно хранятся ненулевые элементы матрицы. Боковые диагонали при этом определяются нулями к размерам n"
Миниатюры
Ленточная матрица  
0
4 / 3 / 1
Регистрация: 07.11.2019
Сообщений: 330
11.09.2022, 23:11  [ТС]
Как я поняла недостающие элементы заполняются нулями, конечно если я не ошибаюсь

Добавлено через 44 минуты
Забыла, вот код который у меня есть на данный момент
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
import java.util.Random;
import java.util.Scanner;
import java.util.stream.IntStream;
 
public class Matrix {
 
    public static void printMatrixDiagonally(int[][] mat) {
        if (mat == null || mat.length == 0) {
            return;
        }
 
        int M = mat.length;
        int N = mat[0].length;
 
        for (int r = M - 1; r >= 0; r--) {
            for (int i = r, j = 0; j >= 0 && i < M; i++, j++) {
                System.out.print(mat[i][j] + " ");
            }
            System.out.print(System.lineSeparator());
        }
        for (int c = N - 1; c >= 0; c--) {
            for (int i = 0, j = c; j < N && i >= 0; i++, j++) {
                System.out.print(mat[i][j] + " ");
            }
            System.out.print(System.lineSeparator());
        }
    }
 
    public static void main(String[] args)
    {
        Scanner in = new Scanner(System.in);
        System.out.println("Матрица: ");
        int MSIZE = in.nextInt();
        int[][] matrix = new int[MSIZE][MSIZE];
 
        Random rnd = new Random();
        for (int i = 0; i < MSIZE; i++) {
            for (int j = 0; j < MSIZE; j++)
                matrix[i][j] = 0;
        }
        for (int i = 0; i < MSIZE; i++) {
            int i2 = rnd.nextInt(MSIZE);
            matrix[i2][i] = rnd.nextInt(10);
        }
        for (int i = 0; i <= matrix.length; i++) {
            for (int j = 0; j < MSIZE; j++) {
                if (i == j) {
                    int i2 = rnd.nextInt(MSIZE);
                    matrix[i][i] = rnd.nextInt(10);
                }
            }
        }
 
        System.out.printf("Вывод матрицы:\n");
        for (int i = 0; i < MSIZE; i++) {
            for (int j = 0; j < MSIZE; j++) {
                System.out.printf("%2d\t", matrix[i][j]);
            }
            System.out.println();
        }
        System.out.printf("--------------------\n");
 
        printMatrixDiagonally(matrix);
    }
}
Добавлено через 4 часа 6 минут
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.09.2022, 23:11
Помогаю со студенческими работами здесь

Дана разряженная ленточная матрица. Найти сумму её элементов.
Дана разряженная ленточная матрица. Найти сумму её элементов. Не разобрался я с этими матрицами еще, а сроки к сдаче. Может кто помочь?

Дана разреженная ленточная матрица. Найти матрицу, обратную к ней
Добрый день! Уважаемые знатоки, подскажите пожалуйста с выполнением задачки! Препод сказал написать на с++, а мы толком не проходили...

Ленточная форма
Кто кивирялся с Аксес наверное видел: форма может иметь вид: одиночной и ленточной (типа грида, но с возможностью вывода полей в...

Ленточная форма
Здравствуюйте ,уважаемые программисты, столкнулся с проблемой и не знаю как решить. Проблема состоит в том что у меня не получается...

Ленточная форма
Всем привет. Не как я не могу вникнуть во вложеную форму и в разделенную форму. Хотя мне Eugene-LS скидывал пример. Я не втупляю. У меня...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 30.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru