Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
Hack123
0 / 0 / 0
Регистрация: 15.05.2016
Сообщений: 7
#1

Восстановление палиндрома

16.05.2016, 16:58. Просмотров 809. Ответов 2
Метки нет (Все метки)

Если возможных палиндромов больше одного, вывести лексикографически минимальный (т.е. тот, который бы в словаре следовал ранее всех)

Вход
aoqmaom

Выход
amoqoma
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.05.2016, 16:58
Ответы с готовыми решениями:

Удаление палиндрома
Добрый день , надо написать код , чтобы из веденной строки удалялись слова...

Анаграмма палиндрома
Помогите пожалуйста с решением задачи в c++ . Задана некоторая фраза....

Поиск Палиндрома
Нужна Ваша помощь в решении задачи: Палиндром - это число, запись которого...

Вывод палиндрома.
#include <iostream> #include <conio.h> using namespace std; bool...

Нахождение палиндрома.
Написать функцию, которая определяет, является ли строка палиндромом. Заголовок...

2
Геомеханик
785 / 592 / 937
Регистрация: 26.06.2015
Сообщений: 1,409
16.05.2016, 19:25 #2
Лучший ответ Сообщение было отмечено Hack123 как решение

Решение

Вот набросал по простому.
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
81
82
83
84
85
86
87
88
#include <iostream>
 
struct sign {
    int  n;
    char c;
};
 
bool build_p(char* d, const char* s){
    int   n, i, j, m;
    char* p;
    const int N = 26;
    sign  k, abc[N];
 
    for(i = 0; i < N; ++i){
        abc[i].c = 'a' + i;
        abc[i].n = 0;
    }
 
    while(*s){
        if(*s >= 'a' && *s <= 'z')
            ++abc[*s - 'a'].n;
        else if(*s >= 'A' && *s <= 'Z')
            ++abc[*s - 'A'].n;
        ++s;
    }
 
    for(m = n = j = i = 0; i < N; ++i){
        if(abc[i].n & 1)
            ++j;
        else if(!abc[i].n)
            ++n;
        m += abc[i].n;
    }
    if((j > 1) || !n || (n == N))
        return false;
 
    //сортируем вставкой по кол-ву
    for(j = 1; j < N; ++j){
        k = abc[j];
        i = j - 1;
        while((i >= 0) && ((abc[i].n < k.n)|| ((abc[i].n == k.n) && (abc[i].c > k.c)))){
            abc[i + 1] = abc[i];
            --i;
        }
        abc[i + 1] = k;
    }
 
    //строим палиндром
    p    = d + m;
    *p-- = '\0';
    for(j = 1; j != 0; ){
        for(j = i = 0; i < N; ++i){
            if(abc[i].n & 1){
                if(abc[i].n > 1){
                    while(abc[i].n > 1){
                        *d++ = abc[i].c;
                        *p-- = abc[i].c;
                        abc[i].n -= 2;
                    }
                } else {
                    *d++ = abc[i].c;
                    j    = 0;
                    break;
                }
            } else {
                while(abc[i].n > 0){
                    *d++ = abc[i].c;
                    *p-- = abc[i].c;
                    abc[i].n -= 2;
                }
            }
            if(abc[i].n > 0)
                j = 1;
        }
    }
    return true;
}
 
int main(void){
    char s[32] = "aoqmaom";
    char d[32];
 
    if(build_p(d, s))
        std::cout << d << std::endl;
    else
        std::cerr << "error build!" << std::endl;
    return 0;
}
0
Hack123
0 / 0 / 0
Регистрация: 15.05.2016
Сообщений: 7
16.05.2016, 19:44  [ТС] #3
Геомеханик, ну спасибо,,,но может у тебя есть вариант,,, c помощью sting и buck?
и ещо Задано слово, состоящее из маленьких латинских букв
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.05.2016, 19:44

Нахождение палиндрома
Написать функцию, которая определяет, является ли строка палиндромом. Заголовок...

Нахождение палиндрома в строке
Народ помогите плз!!! Строка состоит из слов. Найти все самые длинные...

Разбить строку на 4 палиндрома
Здравствуйте! Условие: Дана строка s.Нужно разбить ее на 4 палиндрома. ...


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

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

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