С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/9: Рейтинг темы: голосов - 9, средняя оценка - 4.89
0 / 0 / 0
Регистрация: 21.11.2019
Сообщений: 5

Дана матрица размера M × N. Вывести ее элементы в порядке возрастания, расположенные в столбцах с нечетными номерами

01.05.2020, 16:10. Показов 1920. Ответов 2

Студворк — интернет-сервис помощи студентам
Здравствуйте , есть задача: Дана матрица размера M × N. Вывести ее элементы в порядке возрастания, расположенные в столбцах с нечетными номерами (1,3,...)
объясните пожалуйста как вывести эти элементы именно на нечетных столбцах , если быть откровенным пытался мудрить и испоганил свой код настолько что он не выполняет не одно условие , сначала пробовал заменить порядок возрастания на убывание , это работает , но все никак не получалось привязать к нечетным столбцам , подскажите как это сделать правильно , и еще где бы можно было найти качественную литературу с хорошими примерами для такого нуба как я ?
C++
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
#include <iostream>
#include <time.h>
 
using namespace std;
int main()
{
    setlocale(0, "Ru");
    int i, j, n;
    srand(time(NULL));
    cout << "Введите размер квадратной матрицы: "; cin >> n;
    int** mas = new int* [n];
    for (i = 0; i < n; i++) mas[i] = new int[n];
    int* mac = new int[n];
    cout << "Исходный массив:" << endl;
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            mas[i][j] = rand() % 100 - 10;
            cout << mas[i][j] << "\t";
        }
        cout << "\n";
    }
    for (j = 0; j < n; j++)
    {
        for (i = 0; i < n; i++)
        {
            if (mas[j][i] % 1 == 0)
            {
                mac[j] = 0;
            }
            
        }
    }
    for (i = 0; i < n; i++) cout << mac[i] << " ";
    cout << "\n";
    for (j = 0; j < n; j++)
    {
        if (mac[j] == 1)
        {
            for (i = 0; i < n; i++)
            {
                for (int k = n - 1; k > i; k--)
                {
                if (mas[k - 1][j] < mas[k][j])
                    {
                        int buf = mas[k - 1][j];
                        mas[k - 1][j] = mas[k][j];
                        mas[k][j] = buf;
                    }
                }
            }
        }
    }
    cout << "Массив после преобразования:" << endl;
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            cout << mas[i][j] << "\t";
        }
        cout << "\n";
    }
    cout << "\n";
    system("pause");
    return 0;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.05.2020, 16:10
Ответы с готовыми решениями:

Дана матрица размера MxN. Вывести ее элементы, расположенные в столбцах с нечетными номерами
Дана матрица размера MxN. Вывести ее элементы, расположенные в столбцах с нечетными номерами (1, 3, …). Вывод элементов производить по...

Дана матрица размера M х N. Вывести ее элементы, расположенные в столбцах с нечетными номерами (1, 3, …)
Помогите, очень срочно нужно.... Дана матрица размера M х N. Вывести ее элементы, расположенные в столбцах с нечетными номерами (1,...

Дана матрица размера M×N. Вывести ее элементы, расположенные в столбцах с нечетными номерами (1,3, ...)
Помогите с задачей, Пожалуйста. Есть на языке Paskal -Дана матрица размера M×N. Вывести ее элементы, расположенные в столбцах с...

2
 Аватар для FFPowerMan
2156 / 1236 / 508
Регистрация: 11.10.2018
Сообщений: 6,237
01.05.2020, 16:23
Цитата Сообщение от Vvas Посмотреть сообщение
C++
1
2
3
for(j = 0; j < n; j++)
{
    for(i = 0; i < n; i++)
- зачем меняете i и j. Это только запутывает программу.
По Вашей теме, просто задаете начальное значение столбца 1 и потом прибавляете 2 j += 2.

Добавлено через 2 минуты
Цитата Сообщение от Vvas Посмотреть сообщение
C++
1
2
3
4
if (mas[j][i] % 1 == 0)
{
    mac[j] = 0;
}
- делить число на 1 и брать остаток, мда.........
Вы завели дополнительный массив, скопируйте туде все нечетные столбцы как я сказал выше.
Потом просто отсортируйте функцией sort и выведите на экран.

Добавлено через 2 минуты
Цитата Сообщение от Vvas Посмотреть сообщение
C++
1
int* mac = new int[n];
- вот он, размер только у него будет не n, а (M*N)/2 или для квадратной матрицы pow(n, 2)/2.

Добавлено через 29 секунд
И не забудьте память удалить/высвободить.
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
01.05.2020, 17:08
FFPowerMan, размер M*N/2 только когда N чётное

Vvas, Вы похоже пытаетесь решать другую задачу (сортировать столбцы по возрастанию)
C++
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
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
 
int main()
{
    srand((int)time(0));
    int M, N, K, p=0;
    cout << "M="; cin >> M;
    cout << "N="; cin >> N;
    
      double **a = new double*[M]; 
    for (int i = 0; i < M; i++)
      a[i]=new double[N];
      
    if(N%2==0) K=M*N/2; else K=M*(N+1)/2;  
    
       double *b = new double[K];
    
    for (int i = 0; i < M; i++)
    {
        for (int j = 0; j < N; j++)
        {
        a[i][j]=rand()%9 + 1;
        if(j%2==0) b[p++]=a[i][j];
        cout << a[i][j] << " ";
        }
    cout << "\n";
    }
    cout << "\n";    
    
    for (int i=0; i<K-1; i++)    
    for (int j=0; j<K-i-1; j++)        
      if (b[j] > b[j+1]) 
      swap(b[j],b[j+1]);
    
    for (int i = 0; i < K; i++)         
        cout << b[i] << " ";            
    cout << "\n";
 
    for (int i = 0; i < M; i++)
    delete[]a[i];
    delete[]a;
    delete[]b;
system("pause");
return 0;
}
Добавлено через 6 минут
Цитата Сообщение от Vvas Посмотреть сообщение
Введите размер квадратной матрицы
матрица не обязательно квадратная
Цитата Сообщение от Vvas Посмотреть сообщение
Массив после преобразования
преобразовывать массив по условию не требуется
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.05.2020, 17:08
Помогаю со студенческими работами здесь

1.Дана матрица размера M × N. Вывести ее элементы, расположенные в строках с четными номерами (2, 4, …). Вывод элементов
помогите, что я не так делаю ? я честно пытался 1.Дана матрица размера M × N. Вывести ее элементы, расположенные в строках с четными...

Вывести элементы матрицы расположенные в столбцах с нечетными номерами
Подскажите, где ошибка в программе условие:Дана матрица размера M £ N. Вывести ее элементы, расположенные в столбцах с нечетными...

Вывести элементы матрицы, расположенные в столбцах с нечетными номерами
Дана матрица размера MxN. Вывести ее элементы, расположенные в столбцах с нечетными номерами. Вывод элементов производить по столбцам,...

Вывести элементы матрицы, расположенные в столбцах с нечетными номерами
Вывести элементы, расположенные в столбцах с нечетными номерами (1, 3, …). Вывод элементов производить по столбцам, условный оператор не...

Вывести элементы матрицы, расположенные в столбцах с нечетными номерами
Дана матрица размера M x N. Вывести ее элементы, расположенные в столбцах с нечетными номерами (1, 3, ...). Вывод элементов произво-дить...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
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-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru