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

Продублировать через 1 пробел слова, являющиеся палиндромами четной длины

28.06.2015, 23:04. Просмотров 846. Ответов 1
Метки нет (Все метки)

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

В первую строку первого файла переписать слова с четной длиной через пробел, во вторую — с нечетной
Короче говоря, проблема такова: Дан файл со строками, нужно в первую строку...

Вывести все слова четной длины, у которых все буквы из первой половины слова встречаются во второй
Задача: Дана последовательность символов, состоящая из слов четной длины....

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

Как задать одномерный массив чисел четной длины
Здравствуйте! Я только начал обучаться си. Вот перешел к массивам, но не...

Продублировать рядом слова, в которых все символы различны
Со строками вообще проблемы. Помогите написать такую программу. Вводится...

1
Геомеханик
786 / 593 / 937
Регистрация: 26.06.2015
Сообщений: 1,409
29.06.2015, 08:16 #2
Лучший ответ Сообщение было отмечено kvpkarina как решение

Решение

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 <stdio.h>
#include <string.h>
#include <ctype.h>
 
 
char* poly_rep(char* s, size_t N){
    char*  p, *i, *o, *t = s;
    size_t k, l, n = strlen(s) + 1;
 
    while(*s){
        while(*s && ! isalnum(*s))
            ++s;
 
        p = s + 1;
        while(isalnum(*p))
            ++p;
        
        l = (size_t)(p - s);
        if(! (l % 2)){
 
            i = p - 1;
            o = s;
            while((s < i) && (*s == *i)){
                ++s;
                --i;
            }
 
            if(s > i){
                if((n + l + 1) >= N)
                    break;
 
                k  = (size_t)(o - t);
                memmove(p + 1, o, (n - k) * sizeof(char));
                *p = ' ';
                p += l + 1;
                n += l + 1;
            }
        }
        s = p;
    }
    return t;
}
 
 
int main(void){
    char s[64] = "KOOK, wow [ABBA], bla 21LL12";
 
    puts(s);
    puts( poly_rep(s, sizeof(s)- 1) );
    return 0;
}
Результат работы кода
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.06.2015, 08:16

Задано предложение и слово. Продублировать n-ое вхождение слова в него
Задано предложение и слово. Продублировать n-ое вхождение слова в него. Если...

Дан текстовый файл. Переписать в новый файл все его строки четной длины
помогите написать программу заранее спасибо Дан текстовый файл. Переписать в...

Считывание чисел через пробел в массив через scanf
Здравствуйте! Очень вероятно что вопрос поднимался миллионы раз, но я ответы...


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

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

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