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

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

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

задача на строки - C++

19.02.2012, 19:41. Просмотров 483. Ответов 3
Метки нет (Все метки)

помогите пожалуйста, хотя бы на словах подскажите алгорит к след.задаче
Ввести n слов в консоли. Найти слово ,в котором число различных символов минимально. Если таких слов несколько, то вывести первое.

Я примерно представляю себе алгоритм, но никак не могу сдвинуться в его реализации((
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.02.2012, 19:41     задача на строки
Посмотрите здесь:

Задача на строки C++
C++ Задача на строки
C++ задача на Строки
C++ Задача, строки, с++
C++ Задача на строки !
C++ задача на строки
C++ Задача на строки
C++ Задача на строки(С/С++)
Задача на строки C++
C++ Задача на строки
Задача на строки C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
go
Эксперт C++
3586 / 1366 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
19.02.2012, 19:53     задача на строки #2
std::unique Вам поможет.
R136a1
142 / 111 / 15
Регистрация: 14.04.2011
Сообщений: 261
19.02.2012, 20:23     задача на строки #3
кривовато только получилось, но работает
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 <cstring>
 
int main()
{
    char str[80];
    char *strPtr;
    char *word = 0;
    int count = 80;
    bool gate = false;
 
    std::cin.getline(str,80);
 
    strPtr = strtok(str," ");
 
    while(strPtr != NULL)
    {
        int temp = 0;
 
        for(int i = 0; *(strPtr + i) != '\0'; i++)
            for(int j = i + 1; *(strPtr + j) != '\0'; j++)
                if(*(strPtr + i) != *(strPtr + j))
                    temp++;
        if(count > temp)
        {
            if(gate)
                delete[] word;
 
            word = new char[strlen(strPtr)+1];
            strcpy(word,strPtr);
            count = temp;
 
            gate = true;
        }
 
        strPtr = strtok(NULL," ");
 
    }
 
    std::cout << word << std::endl;
 
    delete[] word;
 
    return 0;
}
easybudda
Эксперт С++
9452 / 5465 / 926
Регистрация: 25.07.2009
Сообщений: 10,490
19.02.2012, 21:48     задача на строки #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
#include <iostream>
#include <string>
#include <sstream>
#include <set>
#include <algorithm>
#include <iterator>
 
size_t different_letters(const std::string & word){
    return std::set<char>(word.begin(), word.end()).size();
}
 
struct CmpByDiffLetters {
    bool operator () (const std::string & a, const std::string & b) const {
        return different_letters(a) < different_letters(b);
    }
};
 
int main(){
    std::string str;
    
    while ( std::cout << "String: " && std::getline(std::cin, str) && ! str.empty() ){
        std::istringstream ist(str);
        std::set<std::string, CmpByDiffLetters> set;
        std::copy(std::istream_iterator<std::string>(ist), std::istream_iterator<std::string>(), std::inserter(set, set.begin()));
        if ( set.empty() ){
            std::cerr << "No words found, try one more time..." << std::endl;
            continue;
        }
        std::cout << "First word with minimum different letters: " << *set.begin() << std::endl;
    }
    
    return 0;
}
Yandex
Объявления
19.02.2012, 21:48     задача на строки
Ответ Создать тему
Опции темы

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