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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 21, средняя оценка - 4.62
Alex Ved
Сообщений: n/a
#1

Найти все возможные варианты написания слова в верхнем и нижнем регистрах букв. - C++

06.07.2010, 10:26. Просмотров 2543. Ответов 2
Метки нет (Все метки)

Хотелось бы увидеть кусочек кода, который выполнял бы следующее: Есть слово "Напримерэто". Как мне вывести на экран (в файл, принтер - без разницы) весь список возможных вариантов этого слова, но в различных регистрах
Пример:
Напримерэто
НАпримерэто
НАПримерэто
....
напримерЭТО
напримерэТО
напримерэтО
.....
НаПрИмЕрЭтО
.....
наПРитмерЭто & etc.

Заранее благодарен.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
06.07.2010, 10:26
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Найти все возможные варианты написания слова в верхнем и нижнем регистрах букв. (C++):

Найти все возможные варианты 4 переменных сумма которых больше 7 и меньше 10 - C++
Необходимо реализовать программу, которая перебирает все возможные варианты 4 переменных сумма которых больше 7 и меньша 10.

Все возможные перестановки букв слова - нужен алгоритм - C++
Доброго времени суток, форумчане. Помогите пожалуйста найти/составить алгоритм решения следующей задачи: Дано слово. Найти все возможные...

Найти все возможные комбинации четырех букв - C++
Есть задача с 4 буквами.A,B,C,D нужно найти все возможные комбинации этих букв. Комбинации если я не путаю не чего считаются так...

Вывести все возможные варианты перестановок от 1 до n - C++
Здравствуйте, у меня есть массив чисел от 1 до n, нужно чтобы выводились все возможные варианты перестановок по порядку, то есть для трёх...

Получить все возможные варианты загрузки ящиков - C++
На перевозку 800 кг овощей с базы подготовлены ящики. В них можно загрузить по 8, 10 и 15 килограммов. Получить все возможные варианты...

Вывести все возможные варианты разреза трубы - C++
Вводится длина трубы, количество заготовок (1, 2, 3, 4 ил 5), которые можно вырезать из трубы, и длина каждой заготовки. Вывести все...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Mr.X
Эксперт С++
3049 / 1694 / 265
Регистрация: 03.05.2010
Сообщений: 3,867
06.07.2010, 14:19 #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
///////////////////////////////////////////////////////////////////////////////////
//  Вывести на экран весь список возможных вариантов слова в различных регистрах.
///////////////////////////////////////////////////////////////////////////////////
#include <algorithm>
#include <bitset>
#include <cmath>
#include <iostream>
#include <limits>
#include <locale>
#include <string>
 
typedef std::string  T_str;
 
void print_razn_case(T_str  word)
{
    static const int WORD_LEN_MAX = std::numeric_limits<unsigned long>::digits;    
    if(word.size() > WORD_LEN_MAX)
    {
        std::cout << "Слово должно быть не длиннее "
                  << WORD_LEN_MAX
                  << "."
                  << std::endl;
        return;
    }    
    
    struct T_make_case
    {
        char operator() (char symbol, char upper_flag)
        {
            return  upper_flag == '1' ? std::toupper(symbol, std::locale(""))                             
                                      : std::tolower(symbol, std::locale(""));                            
        } 
    };
    double  variants_total = pow(static_cast<double>(2), static_cast<int>(word.size()));
    typedef std::bitset<WORD_LEN_MAX>  T_upper_flags;    
    for(
           T_upper_flags  upper_flags; 
           upper_flags.to_ulong() < variants_total; 
           upper_flags = T_upper_flags(upper_flags.to_ulong() + 1) 
       )
    {      
        /*
        T_str  upper_flags_str = upper_flags.template to_string
                                 <char, std::char_traits<char>, std::allocator<char> >();       
        */
        T_str  upper_flags_str = upper_flags.to_string();      
        std::transform(word.begin(), word.end(),
                       upper_flags_str.begin() + WORD_LEN_MAX - word.size(), 
                       std::ostream_iterator<char>(std::cout, ""),
                       T_make_case());
        std::cout << std::endl;       
    }    
    std::cout << "Всего вариантов "
              << variants_total
              << "."
              << std::endl;
}
 
int main()
{
    std::locale::global(std::locale("rus"));        
    T_str  word = "Напримерэто";                    
    print_razn_case(word);    
    return 0;
}
2
uggway
219 / 133 / 9
Регистрация: 12.04.2010
Сообщений: 248
06.07.2010, 16:20 #3
Менее страшно...
C++
1
2
3
4
5
6
7
8
9
10
char *s = "напримерэто", v;
    int l = strlen(s);
    for(int i = 0; i < 1 << l; i++)
    {
        for(int j = 0; j < l; j++){
            if(i & (1<<j)) v = toupper(s[j]); else v = tolower(s[j]);
            cout << v;
        }
        cout << endl;
    }
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.07.2010, 16:20
Привет! Вот еще темы с ответами:

Рассчитать все возможные варианты для 3 знаков - C++
Дано: 1 2 0 Найти все возможные комбинации 10 разрядного числа (пример: 1021020021) и чтобы можно задавать разные условия для кол-ва...

Все возможные варианты перестановки символов строки - C++
Дана строка s, состоящая из n символ (n меньше 6) составить все возможные варианты перестановки этих символов (язык C)

Определить все возможные варианты выплаты суммы N монетами 2 5 10 - C++
Нужно написать программу на С++ в консольным режиме.Пользователь вводит число N.и на экран выводятся все возможные варианты выплаты...

Структуры. Вывести все возможные варианты покупки товаров - C++
может кто нибудь помочь составить прогу /* с++ */ 1) С клавиатуры вводятся записи вида: товар - стринг (название товара) цена -...


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

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

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