Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 20.11.2015
Сообщений: 10
1

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

03.07.2016, 19:04. Показов 981. Ответов 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;
 
}
__________________
Помощь в написании контрольных, курсовых и дипломных работ здесь
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
03.07.2016, 19:04
Ответы с готовыми решениями:

Составить программу нахождения максимального отрицательного элемента матрицы и нахождения его местоположения
Дана вещественная матрица A(N,M). Составить программу нахождения максимального отрицательного...

Написать программу для нахождения максимального из n чисел
Помогите пожалуйста Написать программу в паскаль для нахождения максимального значения из n чисел

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

Дана матрица A(n*n). Написать программу нахождения максимального элемента матрицы
Дана матрица A(n*n). Написать программу нахождения максимального элемента матрицы

4
"C with Classes"
1513 / 1308 / 493
Регистрация: 16.08.2014
Сообщений: 5,467
Записей в блоге: 1
03.07.2016, 19:27 2
Карина7, сначала пишешь код чисто для инт, тестируешь его, если все ок, дополняешь его в шаблон.

Добавлено через 4 минуты
код рабочий? могу переделать в шаблон если рабочий
1
161 / 153 / 92
Регистрация: 18.11.2015
Сообщений: 677
03.07.2016, 20:03 3
У тебя тут одна функция - main(). Из чего прикажете шаблон-то делать?
0
18 / 18 / 15
Регистрация: 05.03.2016
Сообщений: 67
03.07.2016, 20:09 4
Лучший ответ Сообщение было отмечено Карина7 как решение

Решение

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;
 
}
1
0 / 0 / 0
Регистрация: 20.11.2015
Сообщений: 10
03.07.2016, 20:21  [ТС] 5
Ой спасибо огромное, Вы просто молодец)))

Добавлено через 32 секунды
Да рабочий, но мне уже ответили ниже, спасибо)
0
03.07.2016, 20:21
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
03.07.2016, 20:21

Написать программу нахождения максимального элемента матрицы, принадлежащего отрезку [p, q]
Дана матрица А(nxn). Написать программу нахождения максимального элемента матрицы, принадлежащего...

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

Разработать программу для нахождения максимального и минимального элементов действительной матрицы
Разработать программу для нахождения максимального и минимального элементов действительной матрицы...

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


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru