9 / 9 / 4
Регистрация: 22.10.2009
Сообщений: 24

Определить количество различных элементов матрицы

01.11.2009, 21:33. Показов 3653. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
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
//Помогите разобраться в "рабочей" программе.(комментариями!!)
//Условие задачи:Задана символьная матрица размером NxM. Определить количество раз-
//личных элементов матрицы (т.е. повторяющиеся элементы считать один раз). 
 
#include <iostream.h>
#include <iomanip.h>
#include <math.h>
int main(void)
{
    int bp,i,j,k,m,n;
    char **a;
    char b[100];
 
    cout<<"Vvedite n - ";
    cin >>n;
    cout<<"Vvedite m - ";
    cin >>m;
    a=new char*[n];
    for (i=0; i<n; i++)
        a[i]=new char[m];
    for (i=0; i<n; i++)
    {
        for (j=0; j<m; j++)
        {
            cout<< "Vvedite a["<<i<<"]["<<j<<"]=";
            cin>>a[i][j];
        }
        cout<<endl;
    }
    for (i=0; i<n; i++)
    {
        for (j=0; j<m; j++)
            cout << setw (3) << a[i][j] << " ";
        cout << endl;
    }
    for (i=0; i<n; i++)
        for (j=0; j<m; j++)
            b[i*m+j]=a[i][j];
 
    bp=n*m;
    for (i=0;i<bp;i++)
        
     for (j=i+1; j<bp; j++)
     {
         if (b[i]==b[j])
         {
             for (k=j; k<bp-1; k++)
                 b[k]=b[k+1];
             j--;
             bp--;
         }
     }      
 
    cout << bp << endl;
            for (i=0; i<n; i++)
                delete []a[i];
            delete []a;
            a=NULL;
    return 0;
}
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.11.2009, 21:33
Ответы с готовыми решениями:

Определить количество различных элементов матрицы
Задана символьная матрица размером NxM. Определить количество различных элементов матрицы (т.е. повторяющиеся элементы считать один раз)....

Определить количество различных элементов матрицы
Помогите ,пожалуйста ,реализовать программу на языке Си . Определить количество различных элементов матрицы С (повторяющиеся элементы...

Определить количество различных элементов матрицы
помогите ребята! Задана символьная матрица размером N×M, N,M&lt;50. Определить k - количество различных элементов матрицы (т.е....

3
79 / 79 / 8
Регистрация: 14.10.2009
Сообщений: 121
01.11.2009, 22:32
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

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
68
69
70
71
72
73
74
75
76
#include <iostream>//моя правка
#include <iomanip>//моя правка
#include <math.h>
#include <conio.h> //моя правка
 
using namespace std; //моя правка
 
int main(void)
{
    int bp,i,j,k,m,n;
    char **a; //Указатель на указатель на тип char
    char b[100]; //массив 100 чаров
 
    cout<<"Vvedite n - ";
    cin >>n;
    cout<<"Vvedite m - ";
    cin >>m;
    a=new char*[n];  //выделяем память под столбец матрицы
    for (i=0; i<n; i++)
        a[i]=new char[m]; //выделяем память под все строки матрицы
    //Можно нарисовать а:
    /* 
        a->*a------------->**a
           *a------->**a   **a
           *a->      **a   **a
           *a->      **a    
           *a->
    И так далее.
    */
    for (i=0; i<n; i++) //это цыкл по всей матрице.
    {
        for (j=0; j<m; j++)
        {
            cout<< "Vvedite a["<<i<<"]["<<j<<"]=";
            cin>>a[i][j];         //тут мы заполняем элемент матрицы введенным значением.
        }
        cout<<endl;
    }
    for (i=0; i<n; i++) //опять цыкл по всему массиву
    {
        for (j=0; j<m; j++)
            cout << setw (3) << a[i][j] << " "; //просто печатаем на экран нашу матрицу (setw(3) для пробелов)
        cout << endl;
    }
    for (i=0; i<n; i++) //цыкл по всей матрице
        for (j=0; j<m; j++)
            b[i*m+j]=a[i][j]; //тут автор конечно намудрил . . .
    //ненавижу разбирать чужой код
    //б это массив. б[текущий столбец умножить на всего строк + текущая строка]
    //так вот я о чем
    //в этой строке автор просто записал матрицу а в массив б построчно.
 
    bp=n*m; //определяем длинну массива б(она же колличество элементов в матрице)
    for (i=0;i<bp;i++) //цыкл по всему массиву б
        
     for (j=i+1; j<bp; j++) //цыкл по всему массиву б опять, НО начиная с б[1]
     {
         if (b[i]==b[j]) //сравниваем b[n] и b[n+1]
         {
             for (k=j; k<bp-1; k++) //если они равны, топеремещаем хвостик массива влево или другими словами вырезаем из массива повтор. значение.
                 b[k]=b[k+1];
             j--;
             bp--; //и длинну массива тоже урезаем
         }
     }      
 
    cout << bp << endl; //в качестве результата выводим длинну массива б, она же колличество неповтор. элементов
            for (i=0; i<n; i++) //ну а тут просто удаляем из памяти матрицу а(можно пропустить\вырезать)
                delete []a[i]; 
            delete []a;
            a=NULL;
 
    getch(); //моя правка
 
    return 0;
}
1
14 / 14 / 0
Регистрация: 08.07.2009
Сообщений: 61
02.11.2009, 11:40
а как записать новый динамический тип - указатель на матрицу неизвестной размерности элементов - указателей на структуры типа matrix , используя typedef ? Как-то так?
C
1
typedef MATRIX4D matrix[][]
и как потом к элементам обращаться?
0
0 / 0 / 0
Регистрация: 17.09.2011
Сообщений: 9
18.11.2011, 17:47
почему можно ввести в ячейку только однозначную цифру?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.11.2011, 17:47
Помогаю со студенческими работами здесь

Определить количество различных элементов матрицы
помогите пожалуйста ребята! Задана символьная матрица размером N×M, N,M&lt;50. Определить k - количество различных элементов матрицы (т.е....

Определить количество различных элементов матрицы
Ну пожалуйста Помогите ребята!Динамический массив. Задана символьная матрица размером N×M, N,M&lt;50. Определить k - количество...

Определить количество различных элементов матрицы
Дана целая квадратная матрица порядка N. Определить количество различных элементов матрицы (то есть повторяющиеся элементы считать один...

Определить количество различных элементов символьной матрицы
Здравствуйте, помогите, пожалуйста, решить задачку. Задана символьная матрица размером NxM. Определить количество различных элементов...

Динамический массив. Определить количество различных элементов матрицы
Помогите ребята! Задана символьная матрица размером N×M, N,M&lt;50. Определить k - количество различных элементов матрицы (т.е....


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

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

Новые блоги и статьи
sshd restrictions, ssh access limitations
jigi33 26.03.2025
sshd restrictions | ssh access limitations рестрикции доступа на сервер sshd статья: https:/ / www. golinuxcloud. com/ restrict-allow-ssh-certain-users-groups-rhel
Компиляция C++ с Clang API
NullReferenced 24.03.2025
Компиляторы обычно воспринимаются как черные ящики, которые превращают исходный код в исполняемые файлы. Мы запускаем компилятор командой в терминале, и вуаля — получаем бинарник. Но что если нужно. . .
Многопоточное программировани­е в C#: Класс Thread
UnmanagedCoder 24.03.2025
Когда запускается приложение на компьютере, операционная система создаёт для него процесс - виртуальное адресное пространство. В C# этот процесс изначально получает один поток выполнения — главный. . .
SwiftUI Data Flow: Передача данных между представлениями
mobDevWorks 23.03.2025
При первом знакомстве со SwiftUI кажется, что фреймворк предлагает избыточное количество механизмов для передачи данных: @State, @Binding, @StateObject, @ObservedObject, @EnvironmentObject и другие. . . .
Моки в Java: Сравниваем Mockito, EasyMock, JMockit
Javaican 23.03.2025
Как протестировать класс, который зависит от других сложных компонентов, таких как базы данных, веб-сервисы или другие классы, с которыми и так непросто работать в тестовом окружении? Для этого и. . .
Архитектурные паттерны микросервисов: ТОП-10 шаблонов
ArchitectMsa 22.03.2025
Популярность микросервисной архитектуры объясняется множеством важных преимуществ. К примеру, она позволяет командам разработчиков работать независимо друг от друга, используя различные технологии и. . .
Оптимизация рендеринга в Unity: Сортировка миллиона спрайтов
GameUnited 22.03.2025
Помните, когда наличие сотни спрайтов в игре приводило к существенному падению производительности? Время таких ограничений уходит в прошлое. Сегодня геймдев сталкивается с задачами совершенно иного. . .
Образование и практика
Igor3D 21.03.2025
Добрый день А вот каково качество/ эффективность ВУЗовского образования? Аналитическая геометрия изучается в первом семестре и считается довольно легким курсом, что вполне справедливо. Ну хорошо,. . .
Lazarus. Таблица с объединением ячеек.
Massaraksh7 21.03.2025
Понадобилась представление на экране таблицы с объединёнными ячейками. И не одной, а штук триста, и все разные. На Delphi я использовал для этих целей TStringGrid, и то, кривовато получалось. А в. . .
Async/await в Swift: Асинхронное программировани­е в iOS
mobDevWorks 20.03.2025
Асинхронное программирование долго было одной из самых сложных задач для разработчиков iOS. В течение многих лет мы сражались с замыканиями, диспетчеризацией очередей и обратными вызовами, чтобы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru