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

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

Войти
Регистрация
Восстановить пароль
 
Ruslan228
1 / 1 / 0
Регистрация: 03.11.2015
Сообщений: 61
#1

Передать код под шаблонную функцию - C++

21.06.2016, 09:33. Просмотров 164. Ответов 3
Метки нет (Все метки)

Ребят помоги передать код под одну шаблонную функцию
У меня сделано через перезагрузку функции
Сам код:
C++ (Qt)
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
#pragma hdrstop
#pragma argsused
 
#ifdef _WIN32
#include <tchar.h>
#else
  typedef char _TCHAR;
  #define _tmain main
#endif
 
#include <stdio.h>
#include <iostream.h>
void f(int n, int *mas){
    int j,i,max,min,i_max,i_min,n1,i1,k,w,s;
   max=mas[0];
    min=mas[0];
    for (i=0; i < n; i++) {
            if((mas[i])> max){max=mas[i];}
            if((mas[i])< min){min=mas[i];}
        }
 
        cout<<min<<endl;
        cout<<max<<endl;
        k=-1;
        bool flag;
        for (i = min+1; i < max; i++) {
        flag=true;
                for (j = 0; j <n; j++) {
                    if(i==mas[j]){flag=false;}
                    }
                if(flag==true){k++;}
                }
                cout<<endl;
           int *masq=new int [k] ;
           w=0 ;
        for (i = min+1; i < max; i++) {
        flag=true;
                for (j = 0; j <n; j++) {
                    if(i==mas[j]){flag=false;}
                    }
                if(flag==true){masq[w]=i;w++;}
                }
                cout<<endl;
         cout<<endl;
 
 
}
void f(int n1, float *mas){
    int j,i,i1,k,w,s;
    float max,min;
   max=mas[0];
    min=mas[0];
    for (i=0; i < n1; i++) {
            if((mas[i])> max){max=mas[i];}
            if((mas[i])< min){min=mas[i];}
        }
 
        cout<<min<<endl;
        cout<<max<<endl;
        k=-1;
        bool flag;
        for (i = min+1; i < max; i++) {
        flag=true;
                for (j = 0; j <n1; j++) {
                    if(i==mas[j]){flag=false;}
                    }
                if(flag==true){k++;}
                }
                cout<<endl;
           float *masq1=new float [k] ;
           w=0 ;
        for (i = min+1; i < max; i++) {
        flag=true;
                for (j = 0; j <n1; j++) {
                    if(i==mas[j]){flag=false;}
                    }
                if(flag==true){masq1[w]=i;w++;}
                }
                cout<<endl;
         cout<<endl ;
}
 int _tmain(int argc, _TCHAR* argv[])
{
    int j,i,n,max,min,i_max,i_min,n1,i1,k,w,s;
    cout<<"Skolko buten n : ";
    cin>>n;
    if (n<=1) { cout<<"Oshibka"<<endl;}
    else {
 
        int *mas=new int [n];
        for (i =0 ;i<n; i++) {
        cout<<"Vedyte element : ";
        cin>>mas[i];
    }
    f(n,mas);
                }
    cout<<"Skolko buten n : ";
    cin>>n1;
    if (n1<=1) { cout<<"Oshibka"<<endl;}
    else {
 
        float *mas1=new float [n1];
        for (i =0 ;i<n1; i++) {
        cout<<"Vedyte element : ";
        cin>>mas1[i];
    }
    f(n1,mas1);
                }
 
 
 
 
 
 
    system("pause");
    return 0;
}
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.06.2016, 09:33
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Передать код под шаблонную функцию (C++):

Передача указателя на шаблонную функцию в другую функцию - C++
Пишу тест для нескольких улучшений квиксорта с измерением времени. Функция benchmark принимает итераторы для диапазона элементов, указатель...

Написать шаблонную функцию - C++
Здравстсвуйте,нужно переделать функцию под шаблонную.Я вроде как сделал,но компилятор ругается.Работаю в Rad Xe2. Вот код #pragma...

Как построить шаблонную функцию? - C++
Добрый вечер! Есть код, который всегда повторяется в дочерних классах: QPushButton *button = new QPushButton(QIcon(&quot;:/icons/&quot; + icon +...

Реализовать шаблонную функцию minimum - C++
которая находит минимальный элемент, который хранится в экземпляре шаблонного класса Array, при этом типовой параметр шаблона Array может...

Std::function на шаблонную функцию - C++
Здравствуйте :) Делаю такую вещь: template &lt;typename T1, typename T2&gt; typename std::common_type&lt;T1,T2&gt;::type func(T1 val1, T2 val2) ...

Реализовать шаблонную функцию поиска компонентов - C++
Привет всем. Такой вопрос: Есть класс Object и класс Component. У класса Component могут быть наследники RigidBodyComponent,...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
zss
Модератор
Эксперт С++
6382 / 5947 / 1927
Регистрация: 18.12.2011
Сообщений: 15,264
Завершенные тесты: 1
21.06.2016, 10:20 #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
#include <iostream>
using namespace std;
template<class T>
void f(int n1, T *mas)
{
    T max,min;
    max=mas[0];
    min=mas[0];
    for (int i=1; i < n1; i++) 
    {
        if( mas[i]> max)
            max=mas[i];
        if( mas[i]< min)
            min=mas[i];
    }
 
    cout<<min<<endl;
    cout<<max<<endl;
    int k=0;
    for (T i = min+1; i < max; i++) 
    {
        for (int j = 0; j <n1; j++)
            if(i==mas[j])
            {
                k++;
                break;
            }
    }
    cout<<endl;
    T *masq1=new T[k] ;
    int w=0 ;
    for (T i = min+1; i < max; i++) 
    {
        for (int j = 0; j <n1; j++) 
        {
            if(i==mas[j])
            {
                masq1[w++]=i;
                break;
            }
        }
    }
    for (int i =0 ;i<w; i++)
        cout<<masq1[i]<<endl;
    cout<<endl;
    delete[] masq1;
}
int main()
{
    cout<<"Skolko buten n : ";
    int n;cin>>n;
    if (n<=1) 
        cout<<"Oshibka"<<endl;
    else 
    {
        int *mas=new int [n];
        for (int i =0 ;i<n; i++) {
            cout<<"Vedyte element : ";
            cin>>mas[i];
        }
        f(n,mas);
        delete[] mas;
    }
    cout<<"Skolko buten n : ";
    cin>>n;
    if (n<=1) 
        cout<<"Oshibka"<<endl;
    else 
    {
        float *mas1=new float [n];
        for (int i =0 ;i<n; i++) {
            cout<<"Vedyte element : ";
            cin>>mas1[i];
        }
        f(n,mas1);
        delete[] mas1;
    }
    system("pause");
    return 0;
}
1
Ruslan228
1 / 1 / 0
Регистрация: 03.11.2015
Сообщений: 61
21.06.2016, 10:37  [ТС] #3
zss, Спасибо!
0
zss
Модератор
Эксперт С++
6382 / 5947 / 1927
Регистрация: 18.12.2011
Сообщений: 15,264
Завершенные тесты: 1
21.06.2016, 10:39 #4
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
Ruslan228, есть кнопочка "Спасибо"!
Если расширить область применения Вашей шаблонной функции, то надо сделать еще небольшие изменения.
Пример - использование комплексных чисел:
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
#include <iostream>
#include <complex>
using namespace std;
template<class T>
void f(int n1, T *mas)
{
    T max,min;
    max=mas[0];
    min=mas[0];
    for (int i=1; i < n1; i++) 
    {
        if( abs(mas[i])> abs(max))
            max=mas[i];
        if( abs(mas[i])< abs(min))
            min=mas[i];
    }
 
    cout<<min<<endl;
    cout<<max<<endl;
    int k=0;
    for (T i = min+T(1); abs(i) < abs(max); i+=T(1)) 
    {
        for (int j = 0; j <n1; j++)
            if(i==mas[j])
            {
                k++;
                break;
            }
    }
    cout<<endl;
    T *masq1=new T[k] ;
    int w=0 ;
    for (T i = min+T(1); abs(i) < abs(max); i+=T(1)) 
    {
        for (int j = 0; j <n1; j++) 
        {
            if(i==mas[j])
            {
                masq1[w++]=i;
                break;
            }
        }
    }
    for (int i =0 ;i<w; i++)
        cout<<masq1[i]<<endl;
    cout<<endl;
    delete[] masq1;
}
int main()
{
    cout<<"Skolko buten n : ";
    int n;cin>>n;
    if (n<=1) 
        cout<<"Oshibka"<<endl;
    else 
    {
        complex<double> *mas1=new complex<double>[n];
        for (int i =0 ;i<n; i++) {
            cout<<"Vedyte element : ";
            cin>>mas1[i];
        }
        f(n,mas1);
        delete[] mas1;
    }
    system("pause");
    return 0;
}
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.06.2016, 10:39
Привет! Вот еще темы с ответами:

Написать шаблонную функцию, сортирующую стек - C++
Как мне сделать чтобы я мог вводить значения любого типа? Писал что то типа: template&lt;typename stack&gt; но эт не верно. С шаблонами...

Можно ли упростить шаблонную функцию сортровки - C++
Есть шаблонная функция, сортирующая пузырьком по возрастанию или убыванию в зависимости от полученного параметра. Но она выглядит громоздко...

Описать шаблонную функцию в cpp-файле - C++
файл h template &lt; class T &gt; class B_tree { private: struct T_node { friend class B_tree; T val;

Как правильно написать шаблонную функцию? - C++
Как правильно написать функцию template ? в функции main не работает #include &quot;stdafx.h&quot; #include &lt;iostream&gt; using namespace...


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

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

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