Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Relike
6 / 6 / 0
Регистрация: 24.04.2013
Сообщений: 260
#1

Найти колличество столбцов матрицы, в которых все элементы одинаковы - C++

19.12.2013, 17:02. Просмотров 297. Ответов 2
Метки нет (Все метки)

Здравствуйте. Мне нужно написать программу которая будет в матрице m на n находить колличество столбцов в которых все элементы одинаковы... Я запутываюсь между строками и столбцами...
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.12.2013, 17:02     Найти колличество столбцов матрицы, в которых все элементы одинаковы
Посмотрите здесь:

C++ Вывести номера строк матрицы, где все элементы одинаковы
C++ Найти количество столбцов матрицы, элементы которых упорядочены по убыванию
Найти количество строк матрицы, все элементы которых различны. C++
Найти количество столбцов матрицы, все элементы которых различны. C++
Выведите номера столбцов матрицы, все элементы которых - четные числа C++
C++ 23. Дана целочисленная матрица А размером N х М. Составить функцию, выводящую номера строк, все элементы которых одинаковы
C++ Найти колличество столбцов в которых есть числа с разными знаками
Сформировать вектор, в который записать номера строк, в которых все элементы массива одинаковы. C++
Найти номера строк матрицы, все элементы которых чётны C++
C++ Найти количество строк двумерной матрицы, все элементы которых различны
C++ Найти количество столбцов матрицы, элементы которых идут по-возрастанию
C++ Найти номера столбцов элементы в каждом из которых одинаковы.

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Genn55
359 / 206 / 38
Регистрация: 26.12.2012
Сообщений: 689
19.12.2013, 17:50     Найти колличество столбцов матрицы, в которых все элементы одинаковы #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
48
49
50
51
52
53
54
55
56
#include <iostream>
using namespace std;
 
int main()
{
 
    int n;
    int m;
    cin >> n >> m;//вводим количество строк и столбцов
    int ** A = new int * [ n ];//объявили двумерныый массив
 
    for ( int i = 0; i < n; i++ )
    {
        A[ i ] = new int [ m ];//выделили память
       for (int j=0; j<m; j++)
        {
       cout<<"mas ["<<i<<"]["<<j<<"]=";//заполняем с клавиатуры
       cin>>A[i][j];
        }
     }
     cout <<"\n";
     for(int i=0;i<n;i++)
    {
        for(int j=0;j<m;j++)
         {
          cout<<A[i][j]<<"\t";// выводим сформированный массив
         }
        cout<<"\n";
    }
 
    int counter = 0;//счетчик будет считать количество верных столбцов
    for ( int i = 0; i < m; i++ )
    {
        bool cur = true;//наш курсорчик будет проходить по столбцам
        for ( int j = 1; j < n; j++ )
        {
            if ( A[ j ][ i ] != A[ j - 1 ][ i ] )
            {
                cur = false;//если не верно меняет состояние
            }
        }
        if ( cur )
            ++counter;//считаем сколько раз изменилось состояние ккурсорчика
    }
    cout<<"\n";
    cout << "We have " << counter << " right sequences." << endl;
//освобождаем память
    for ( int i = 0; i < m; i++ )
    {
        delete A[ i ];//сначала элементы
    }
 
    delete [] A;//потом массив
 
    return 0;
}
Добавлено через 10 минут
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
    int counter = 0;//счетчик будет считать количество верных столбцов
    for ( int i = 0; i < m; i++ )
    {
        bool cur = true;//наш курсорчик будет проходить по столбцам
        for ( int j = 1; j < n; j++ )
        {
            if ( A[ j ][ i ] != A[ j - 1 ][ i ] )
            {
                cur = false;//если не верно меняет состояние
            }
        }
        if ( cur )
            ++counter;//считаем сколько раз изменилось состояние ккурсорчика
    }
    cout<<"\n";
поменять на
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
   int counter = 0;
    for ( int i = 0; i < m; i++ )
    {
        bool cur = true;
        for ( int j = 1; j < n; j++ )
        {
            if ( A[ j ][ i ] != A[ j - 1 ][ i ] )
            {
                cur = false;
            }
            if ( cur == false )
                break;
        }
        if ( cur )
            ++counter;
    }
    cout<<"\n";
более оптимально
Relike
6 / 6 / 0
Регистрация: 24.04.2013
Сообщений: 260
19.12.2013, 18:10  [ТС]     Найти колличество столбцов матрицы, в которых все элементы одинаковы #3
Genn55, Благодарю!
Yandex
Объявления
19.12.2013, 18:10     Найти колличество столбцов матрицы, в которых все элементы одинаковы
Ответ Создать тему
Опции темы

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