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

Строки и перегрузка функций - C++

Восстановить пароль Регистрация
 
Дмитрий12
1 / 1 / 0
Регистрация: 19.02.2011
Сообщений: 70
01.02.2012, 01:45     Строки и перегрузка функций #1
Всем добрый вечер!!!Если есть минутка, помогите сделать эти задания!буду очень благодарен!!

1. Все слова строки, которые начинаются с буквы, отсортировать в алфавитном порядке.

2. Написать перегруженную функцию и основную программу, которая их вызывает:
а)для массива целых чисел находит кол-во максимальных элементов
б)для строки находят длину самого длинного слова.

Добавлено через 1 час 27 минут
Помогите пожалуйста!!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.02.2012, 01:45     Строки и перегрузка функций
Посмотрите здесь:

C++ Перегрузка функций в C++
Перегрузка функций в Си++ C++
C++ Перегрузка функций. Реализация функций
C++ перегрузка функций
C++ Перегрузка функций
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Haster
инженер-системотехник
 Аватар для Haster
109 / 108 / 2
Регистрация: 10.03.2009
Сообщений: 533
01.02.2012, 10:31     Строки и перегрузка функций #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
#include <iostream>
#include <conio.h>
#include <vector>
#include <string>
#include <algorithm>
using namespace std;
//
 
bool MySort (string str1, string str2) 
{ 
    return str1.compare(str2); 
}
 
void main()
{
    vector<string> words;
    string input;
    cout<<"Enter string: "<<endl;
    getline(cin,input,'\n');
 
    bool flag = true;
    size_t pos = 0;
    size_t pos_l = 0;
 
 
    while (flag)
    {
        pos_l = input.find(' ',pos);
        if (pos_l == string::npos)
        {
            string temp = input.substr(pos);
            if (isalpha(temp[0]))
                words.push_back(temp);
            flag = false;
        }
        else
        {
            string temp = input.substr(pos, pos_l-pos);
            if (isalpha(temp[0]))
                words.push_back(temp);
            pos = pos_l+1;
        }
    }
 
    sort(words.begin(), words.end(), MySort);
 
    for (int i = 0; i < words.size(); i++)
        cout<<"word "<<i<<": "<<words[i]<<endl;
 
    getch();
}
Дмитрий12
1 / 1 / 0
Регистрация: 19.02.2011
Сообщений: 70
01.02.2012, 10:48  [ТС]     Строки и перегрузка функций #3
2. Написать перегруженную функцию и основную программу, которая их вызывает:
а)для массива целых чисел находит кол-во максимальных элементов
б)для строки находят длину самого длинного слова.
Haster
инженер-системотехник
 Аватар для Haster
109 / 108 / 2
Регистрация: 10.03.2009
Сообщений: 533
01.02.2012, 10:54     Строки и перегрузка функций #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
#include <iostream>
#include <conio.h>
#include <vector>
#include <string>
#include <algorithm>
using namespace std;
//
 
int FindMax(int a[], int size)
{
    int max = a[0];
    int result = 0;
    for (int i = 1; i < size; i++)
    {
        if (a[i] > max)
            max = a[i];
    }
 
    for (int j = 0; j < size; j++)
    {
        if (a[j] == max)
            result++;
    }
    return result;
}
 
int FindMax(string str)
{
    vector<string> words;
    bool flag = true;
    size_t pos = 0;
    size_t pos_l = 0;
    
    while (flag)
    {
        pos_l = str.find(' ',pos);
        if (pos_l == string::npos)
        {
            string temp = str.substr(pos);
            words.push_back(temp);
            flag = false;
        }
        else
        {
            string temp = str.substr(pos, pos_l-pos);
            words.push_back(temp);
            pos = pos_l+1;
        }
    }
 
    int max = words[0].length();
    for (int i = 1; i < words.size(); i++)
    {
        if (words[i].length() > max)
            max = words[i].length();
    }
    return max;
}
 
void main()
{
 
    int mass[] = { 12, 2, 4, 12, 54, 54, 23, 54, 32, 8, 34, 8, 4, 6, 34, 54};
    
    int max_num = FindMax(mass, sizeof(mass)/ sizeof(int));
    cout <<"Number of max elements = "<<max_num<<endl;
 
    vector<string> words;
    string input;
    cout<<"Enter string: "<<endl;
    getline(cin,input,'\n');
 
    int max_word = FindMax(input);
    cout <<"Max word length = "<<max_word<<endl;
 
    getch();
}
Yandex
Объявления
01.02.2012, 10:54     Строки и перегрузка функций
Ответ Создать тему
Опции темы

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