Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Brilux
0 / 0 / 0
Регистрация: 08.12.2014
Сообщений: 11
1

Найти строку матрицы, в которой наибольшее количество разных чисел, и отсортировать её по убыванию

17.12.2014, 15:30. Просмотров 418. Ответов 4
Метки нет (Все метки)

В двумерном массиве найти строку в которой наибольшее количество разных чисел и отсортировать её за спаданием.
0
QA
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.12.2014, 15:30
Ответы с готовыми решениями:

Найти количество чисел Фибоначчи в массиве. Отсортировать по убыванию все столбцы матрицы. Подсчитать количество слов в
Друзья, помогите пожалуйста. 1. Используя функции сформировать с помощью ДСЧ одномерный массив и...

Найти строку текста, в которой присутствует наибольшее количество одинаковых слов
Найти строку текста, в которой присутствует наибольшее количество одинаковых слов Как это...

Найти строку матрицы, в которой среднее арифметическое число отрицательных значений наибольшее
Двумерный целочисленный массив 6 строки на 3 столбцов. Заполнить его случайными значениями в...

Найти первую строку матрицы, в которой имеется отрицательный элемент, и упорядочить её по убыванию
Саму матрицу получил, это было не так тяжело. Но не нравится компилятору моя переменная min...

Найти строку матрицы, в которой самое наибольшее количество отрицательных чисел
Мне нужно при помощи функции в двухмерном массиве найти строку в которой самое наибольшее...

4
Brilux
0 / 0 / 0
Регистрация: 08.12.2014
Сообщений: 11
22.12.2014, 19:05  [ТС] 2
Код написан, строку находит, но не сортирует. Хелп плиз.

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
#include <iostream>
using namespace std;
int main()
{
    setlocale(LC_ALL, "Russian");
    int k, i, j, n, m;
    int s;
    int A[100][100];
    cout << "Введите количество столбиков ";
    cin >> n;
    cout << "Введите количество строчек ";
    cin >> m;
    for (j = 0; j < m; j++){
        cout << endl;
        for (i = 0; i < n; i++){
            cin >> k;
            A[i][j] = k;
        }
    }
    int cnt = 0, maxcnt = 0, temp = 0;
    for (j = 0; j < m; j++)
    {
        for (i = 0; i < n; i++)
        {
            for (int l = i + 1; l < n; l++)
            if (A[i, j] == A[i, l])
                cnt++;
        }
        if (cnt > maxcnt)
        {
            maxcnt = cnt;
            temp = j;
        }
    }
    cout << "Столбик №" << temp << endl;
    for (int i = 0; i < n; i++)
    {
        if (A[i, temp] < A[i + 1, temp])
        {
            s = A[i + 1, temp];
            A[i + 1, temp] = A[i, temp];
            A[i, temp] = s;
        }
    }
    system("pause");
    return 0;
}
Проблема скорее всего где-то тут)

C++
1
2
3
4
5
6
7
8
9
for (int i = 0; i < n; i++)
    {
        if (A[i, temp] < A[i + 1, temp])
        {
            s = A[i + 1, temp];
            A[i + 1, temp] = A[i, temp];
            A[i, temp] = s;
        }
    }
0
Kerry_Jr
Эксперт PHP
2222 / 2016 / 942
Регистрация: 14.05.2014
Сообщений: 5,898
Записей в блоге: 1
Завершенные тесты: 5
22.12.2014, 19:07 3
Цитата Сообщение от Brilux Посмотреть сообщение
if (A[i, j] == A[i, l])
везде, где так написано измените на нормальное С++-ное обращение [i][j].
1
Brilux
0 / 0 / 0
Регистрация: 08.12.2014
Сообщений: 11
22.12.2014, 19:17  [ТС] 4
Спасибо, теперь компилится, но все-равно не сортирует (
0
Kerry_Jr
Эксперт PHP
2222 / 2016 / 942
Регистрация: 14.05.2014
Сообщений: 5,898
Записей в блоге: 1
Завершенные тесты: 5
22.12.2014, 20:09 5
Цитата Сообщение от Brilux Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
9
for (int i = 0; i < n; i++)
{
    if (A[i][temp] < A[i + 1][temp])
    {
        s = A[i + 1][temp];
        A[i + 1][temp] = A[i][temp];
        A[i][temp] = s;
    }
}
C++
1
2
3
4
5
6
7
8
9
10
for (int i = 0; i < n-1; ++i)
for (int j = i+1; j < n; ++j)
{
    if (A[i][temp] < A[j][temp])
    {
        s = A[j][temp];
        A[j][temp] = A[i][temp];
        A[i][temp] = s;
    }
}
1
22.12.2014, 20:09
Answers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.12.2014, 20:09

Найти максимальный элемент матрицы, и вывести ту строку, которая содержит наибольшее количество четных чисел
Дана матрица А размерности n×n. Найти максимальный элемент и вывести ту строку в этой матрице,...

Упорядочить по убыванию элементы столбца матрицы, содержащего наибольшее количество отрицательных чисел
В матрице А упорядочить по убыванию элементы столбца,содержащего наибольшее количество...

Упорядочить по убыванию элементы столбца матрицы, содержащего наибольшее количество отрицательных чисел
В матрице A упорядочить по убыванию элементы столбца, содержащего наибольшее количество...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.