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

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

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

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

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

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

Вход
aoqmaom

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

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

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

Нахождение палиндрома. - C++
Написать функцию, которая определяет, является ли строка палиндромом. Заголовок функции: bool isPolindrom(const char *s); Написать...

Вывод палиндрома. - C++
#include <iostream> #include <conio.h> using namespace std; bool is_it(const char * s){ const char * i, * n; ...

Нахождение палиндрома - C++
Написать функцию, которая определяет, является ли строка палиндромом. Заголовок функции: bool isPolindrom(const char *s); Написать...

Реализация функции палиндрома - C++
Я написала функцию, функция нормально работает. Но так как я смотрела по примерам, мне не очень нравиться этот момент: for (t = str;...

2
Геомеханик
746 / 552 / 383
Регистрация: 26.06.2015
Сообщений: 1,305
16.05.2016, 19:25 #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
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
Привет! Вот еще темы с ответами:

Возведение палиндрома в квадрат - C++
Всем доброго времени суток. Не могу понять как можно возвести палиндром в квадрат согласно условию. Если кто может помочь буду...

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

Функция определения палиндрома - C++
Напишите функцию, которая называется IsPalindrom возвращает bool принимает параметр типа string и возвращает, является ли...

Проверка палиндрома через массив - C++
#include &lt;iostream&gt; using namespace std; int t=1; int main() { setlocale(0,&quot;rus&quot;); cout&lt;&lt;&quot;Vvedi czislo &quot;&lt;&lt;endl; int...


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

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

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