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

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

Войти
Регистрация
Восстановить пароль
 
Карина7
0 / 0 / 0
Регистрация: 20.11.2015
Сообщений: 10
#1

Добавить шаблоны в программу нахождения количество строк и максимального из чисел матрицы - C++

03.07.2016, 19:04. Просмотров 333. Ответов 4
Метки нет (Все метки)

Всем привет, я уже как то спрашивала про шаблоны функции, спасибо Вам кто помог, но не могу я никак эту прогу сделать чтоб она работала с шаблонами((( шаблоны int, float, double, мб кто нибудь разбирается в шаблонах и поможет
Прога находит 1) количество строк, не содержащих ни одного нулевого элемента, 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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
#include <iostream>
#include <locale>
#include <iomanip>
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "Russian");
    int const n = 3;
    int m[n][n];
    cout << "Введите матрицу: \n";
    for(int i = 0; i < n; i++)
    {
        for(int j = 0; j < n; j++)
        {
            cout << "Введите элемент[" << i+1 << "][" << j+1 << "]: ";
            cin >> m[i][j];
        }
    }
 
    cout << "\n";
    cout << "Исходная матрица: \n";
    for(int i = 0; i < n; i++)
    {
        cout << endl;
        cout << "\t";
        for(int j = 0; j < n; j++)
        {
            cout << setw(3) << setiosflags(ios::left) << m[i][j] << " " ;
        }
    }
    cout << "\n\n";
    //1)    количество строк, не содержащих ни одного нулевого элемента;
    
    int s = 0;
    for(int i = 0; i < n; i++)
    {
        int c = 0;
        for(int j = 0; j < n; j++)
        {
            if(m[i][j] == 0)
            {
                c++;
            }
        }
 
        if(c == 0)
            s++;
    }
 
    cout << "Kоличество строк, не содержащих ни одного нулевого элемента: " << s;
    cout << "\n\n";
 
    //2)максимальное из чисел, встречающихся в заданной матрице более одного раза.   
int a;
int t=1;
while(t)
    {
     t=0;
 for(int i = 0; i < n; i++)
    {
        for(int j = 0; j < n; j++)
        {
            if(m[i][j]<m[i][j+1])
            {
                t=1;
                a=m[i][j+1];
                m[i][j+1]=m[i][j];
                m[i][j]=a;
            }
        }
    }
}
 
int p=0;
int p1=0;
 
    for(int i = 0; i < n; i++)
    {
        for(int j = 0; j < n; j++)
        {
            if(m[i][j]==m[i][j+1])
            {
               p=m[i][j];
               
            }
            
            if (p>p1)
            {
                p1=p;
                cout << "Максимальное из встречающихся более 1 раза: " << p1;
                cout << "\n\n";
            }
 
        }
    }
 
 system ("pause");
    return 0;
 
}
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.07.2016, 19:04
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Добавить шаблоны в программу нахождения количество строк и максимального из чисел матрицы (C++):

Составить программу для нахождения максимального из 4 чисел - C++
Составить программу для нахождения максимального из 4 чисел.Используя функцию нахождения максимального

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

Написать программу нахождения суммы максимального и минимального из трёх чисел... - C++
Написать программу нахождения суммы максимального и минимального из трёх чисел...

Нахождения максимального из двух чисел - C++
2 С помощью механизма перегрузки функций реализовать функции для нахождения максималь-ного из: 1) 2-х чисел; 2) длин 2-х строк; ...

Процедуры нахождения максимального из двух чисел - C++
Даны действительные А,В,С. Найти значение выражения max(a,b)+max(a,c)+max(b,c) С использованием процедуры нахождения максимального из двух...

Подсчитать количество строк заданной матрицы составленых из различных чисел - C++
Подсчитать количество строк заданной матрицы, которые составлены из различных чисел. Выполнить задание, используя динамическое выделение...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
_stanislav
12 / 61 / 22
Регистрация: 16.08.2014
Сообщений: 408
Завершенные тесты: 2
03.07.2016, 19:27 #2
Карина7, сначала пишешь код чисто для инт, тестируешь его, если все ок, дополняешь его в шаблон.

Добавлено через 4 минуты
код рабочий? могу переделать в шаблон если рабочий
meJevin
155 / 147 / 58
Регистрация: 18.11.2015
Сообщений: 649
Завершенные тесты: 1
03.07.2016, 20:03 #3
У тебя тут одна функция - main(). Из чего прикажете шаблон-то делать?
SimonR
18 / 18 / 7
Регистрация: 05.03.2016
Сообщений: 67
Завершенные тесты: 2
03.07.2016, 20:09 #4
Сообщение было отмечено автором темы, экспертом или модератором как ответ
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
#include <iostream>
#include <locale>
#include <iomanip>
using namespace std;
 
template <typename T>
void Count(T *m, int n )
{
    int s = 0;
    for(int i = 0; i < n; i++)
    {
        int c = 0;
        for(int j = 0; j < n; j++)
        {
            if(m[i][j] == 0)
            {
                c++;
            }
        }
 
        if(c == 0)
            s++;
    }
 
    cout << "Count of strings without 0: " << s;
    cout << "\n\n";
}
 
template <typename T>
void Max(T *m, int n)
{
    int a;
    int t=1;
    while(t)
        {
         t=0;
     for(int i = 0; i < n; i++)
        {
            for(int j = 0; j < n; j++)
            {
                if(m[i][j]<m[i][j+1])
                {
                    t=1;
                    a=m[i][j+1];
                    m[i][j+1]=m[i][j];
                    m[i][j]=a;
                }
            }
        }
    }
 
    int p=0;
    int p1=0;
 
        for(int i = 0; i < n; i++)
        {
            for(int j = 0; j < n; j++)
            {
                if(m[i][j]==m[i][j+1])
                {
                   p=m[i][j];
 
                }
 
                if (p>p1)
                {
                    p1=p;
                    cout << "Max: " << p1;
                    cout << "\n\n";
                }
 
            }
        }
 
}
 
int main()
{
    int const n = 3;
    int m[n][n];
 
//    float m[n][n];
//    char m[n][n];
 
    cout << "Matrix: \n";
    for(int i = 0; i < n; i++)
    {
        for(int j = 0; j < n; j++)
        {
            cout << "Value[" << i+1 << "][" << j+1 << "]: ";
            cin >> m[i][j];
        }
    }
 
    cout << "\n";
    cout << "Result matrix: \n";
 
    for(int i = 0; i < n; i++)
    {
        cout << endl;
        cout << "\t";
        for(int j = 0; j < n; j++)
        {
            cout << setw(3) << setiosflags(ios::left) << m[i][j] << " " ;
        }
    }
    cout << "\n\n";
    //1)    количество строк, не содержащих ни одного нулевого элемента;
    Count(m, n);
 
    //2)максимальное из чисел, встречающихся в заданной матрице более одного раза.
    Max(m, n);
 
    system ("pause");
    return 0;
 
}
Карина7
0 / 0 / 0
Регистрация: 20.11.2015
Сообщений: 10
03.07.2016, 20:21  [ТС] #5
Ой спасибо огромное, Вы просто молодец)))

Добавлено через 32 секунды
Да рабочий, но мне уже ответили ниже, спасибо)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.07.2016, 20:21
Привет! Вот еще темы с ответами:

Реализовать функцию для нахождения максимального элемента заданной матрицы - C++
Задание : Создать прототип функции для нахождения макс. элемента прямоугольной матрицы Есть код для нахождения одномерного массива ...

Подсчитать количество строк матрицы элементы которых представляют перестановки чисел от 1 до n - C++
Дана матрица A порядка n. Подсчитайте количество строк матрицы, элементы которых представляют перестановки чисел от 1 до n. Нужно...

Создать программу для нахождения максимального числа повторений, - C++
Имеется файл RAND.FIL(лежит в архиве) в нём 50000 чисел, от 0 до 90 в двоичной системе! Нужной создать программу которая найдёт...

Подсчитать количество строк заданной целочисленной матрицы n×n, являющихся перестановкой чисел 1, 2, ..., n - C++
Подсчитать количество строк заданной целочисленной матрицы n × n, являющихся перестановкой чисел 1, 2, ..., n (то есть содержащих каждое из...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
03.07.2016, 20:21
Ответ Создать тему
Опции темы

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