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

Шаблонные функции - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.83
Maxvarlamov
1 / 1 / 0
Регистрация: 25.01.2010
Сообщений: 18
22.02.2010, 22:26     Шаблонные функции #1
Помогите, пожалуйста, реализовать шаблонную функцию определения, есть ли число в массиве
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.02.2010, 22:26     Шаблонные функции
Посмотрите здесь:

C++ Шаблонные функции
C++ Шаблонные функции
C++ Шаблонные функции
Шаблонные функции C++
C++ Шаблонные функции
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ISergey
Maniac
Эксперт С++
 Аватар для ISergey
1330 / 863 / 50
Регистрация: 02.01.2009
Сообщений: 2,621
Записей в блоге: 1
22.02.2010, 22:37     Шаблонные функции #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
#include <iostream>
 
template <typename T>
bool foo(const T *arr){ return false; }
 
template <>
bool foo<int>(const int *arr){ return true; }
//.......
 
template <>
bool foo<char>(const char *arr){
    for(int i = 0; i < strlen(arr); ++i)
        if(isdigit(arr[i])) return true;
    return false;
}
int main()
{
 
    int arr[] = {1,2};
    if(foo(arr)) std::cout << "int ok...\n";
 
    const char *arr2 = "aaa1aa";
    if(foo(arr2)) std::cout << "char* (aaa1aa) ok...\n";
 
    //...
    return 0;
}
Vladic
0 / 0 / 0
Регистрация: 18.08.2009
Сообщений: 14
22.02.2010, 22:40     Шаблонные функции #3
Число должно вводится в массив или случайные числа?
Maxvarlamov
1 / 1 / 0
Регистрация: 25.01.2010
Сообщений: 18
22.02.2010, 22:56  [ТС]     Шаблонные функции #4
Число должно вводиться
Vladic
0 / 0 / 0
Регистрация: 18.08.2009
Сообщений: 14
22.02.2010, 23:11     Шаблонные функции #5
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
#include <iostream>
#include <time.h>
#include <stdlib.h>
#include <windows.h>
using namespace std;
 
template <typename T1, typename T2> T2 Scan(T1 A , T2 size) // Проверяем и выводим на экран числа массива
{
    int count = 0;              
    for(int i = 0; i < size; i++)
        if(A[i] >= -1000 && A[i] <= 1000)
            count++;
    if (count==0)
        cout<<"Net chisel"<<endl;
    else
    {
        cout<<"V massive soderzatsya chisla"<<endl;
        for(int i=0; i< size;i++)
        {
           if (A[i] >= -1000 && A[i] <= 1000)
                cout<<A[i]<<endl;
           else 
               continue;
        }
    }
    cout << endl;
    system("PAUSE"); 
    return 0;
}
 
 
void main()
{
    srand(time(NULL));
    const int n = 10;           
    
    int A[n];                   
    for(int i = rand()%10+0; i < n; i++)
    {
        cout<<"Vvedite chislo: \n";           // Вводим числа в массив случайное кол-во раз
        cin>>A[i];
        cout<<endl;
    }  
    Scan(A,n);
}
Как-то так. Подходит, нет? Если число вводиться зачем проверять.
На всякий случай со случайными числами.
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
#include <iostream>
#include <time.h>
#include <stdlib.h>
#include <windows.h>
using namespace std;
 
template <typename T1, typename T2> T2 Scan(T1 A , T2 size)
{
    int count = 0;              
    for(int i = 0; i < size; i++)
        if(A[i] >= -1000 && A[i] <= 1000)
            count++;
    if (count==0)
        cout<<"Net chisel"<<endl;
    else
    {
        cout<<"V massive soderzatsya chisla"<<endl;
        for(int i=0; i< size;i++)
        {
           if (A[i] >= -1000 && A[i] <= 1000)
                cout<<A[i]<<endl;
           else 
               continue;
        }
    }
    cout << endl;
        system("PAUSE");    
    return 0;
}
 
 
void main()
{
    srand(time(NULL));
    const int n = 10;           
    
    int A[n], count;                   
    for(int i = rand()%10+0; i < n; i++)
    {
       A[i]=rand()%1000-1000;
       cout<<A[i]<<endl; //cout для самопроверки, можно убрать или закомментировать
    }
 
    Scan(A,n);
                       
}
Aye Aye
 Аватар для Aye Aye
367 / 281 / 36
Регистрация: 17.12.2009
Сообщений: 567
22.02.2010, 23:35     Шаблонные функции #6
тут шаблонам нечего делать, помоему, или следует задание уточнить.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <iostream>
#include <conio.h>
using namespace std;
bool serch(int *from,int *to,const int &x)
{
     while (from++!=to)if(x==*from++)return true;
     return false;
}
int main()
{
    int a[]={1,6,3,-8,4,2};
    cout << serch(a,a+6,-8)<<endl;
    cout << serch(a,a+6,9)<<endl; 
    getch();
    return 0;
}
from - откуда искать, to - до куда искть, x - что искать.
и вроде мудрить не надо...)

Добавлено через 5 минут
Vladic, а если в моем массиве например цифры от -2000000 до 2000000 будут твоя функция решит что он пустой, и не обработает его?
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.02.2010, 00:06     Шаблонные функции
Еще ссылки по теме:

Шаблонные функции C++
C++ шаблонные функции
Шаблонные функции в C++ C++

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

Или воспользуйтесь поиском по форуму:
Vladic
0 / 0 / 0
Регистрация: 18.08.2009
Сообщений: 14
23.02.2010, 00:06     Шаблонные функции #7
Цитата Сообщение от Aye Aye Посмотреть сообщение
тут шаблонам нечего делать, помоему, или следует задание уточнить.

Vladic, а если в моем массиве например цифры от -2000000 до 2000000 будут твоя функция решит что он пустой, и не обработает его?
Он же ведь и заполняется числами в том промежутке, в котором проверяет.(вариант со случайными числами). А в варианте где вводятся числа можно расширить диапазон проверки до максимальных значений принимаемых типом int, например.
Yandex
Объявления
23.02.2010, 00:06     Шаблонные функции
Ответ Создать тему
Опции темы

Текущее время: 13:39. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru