С Новым годом! Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.85/13: Рейтинг темы: голосов - 13, средняя оценка - 4.85
0 / 0 / 0
Регистрация: 01.03.2013
Сообщений: 3
1

Изменить строку, продублировав слова, из которых можно составить слова-палиндромы четной длины

01.03.2013, 21:18. Показов 2380. Ответов 4
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый вечер всем.

На главной странице я увидел эту надпись:
КиберФорум - форум начинающих и профессиональных программистов, системных администраторов, администраторов баз данных, компьютерный форум. Бесплатная помощь в решении задач по программированию и наукам, решение проблем с компьютером, операционными системами.
Я очень надеюсь на вашу помощь. Нет, не то, чтобы я совсем ничего в этом не понимаю... но эта задача все-таки требует чужого внимания, я думаю. Извините за причиненные неудобства.
Я не буду утомлять вас своим приветствием, поэтому просто напишу здесь саму задачу.
  • Вводится строка символов. Отредактировать строку, продублировав через один пробел слова, из которых можно составить палиндромы четной длины. Результат вывести на экран.
Слово - любая последовательность символов, ограниченная с двух сторон разделителями или разделителем и концом (началом) строки.
Разделитель - один или несколько пробелов.

Спасибо за помощь.

Добавлено через 18 минут
Вот код форумчанина Lilu666. Я пытался видоизменить его для своей задачи, но не знаю, что следует делать. Ведь для моей задачи слово "аббавв" должно дублироваться тоже, потому что в условии сказано "слова, из которых можно составить палиндромы четной длины", то есть если слово будет четной длины с символами, которые повторяются один раз (в данном случае "аббавв" - а, б и в имеют пару, то есть если их переставить, то получится палиндром - "абввба" или "ваббав" и т.д.), то программа должна будет дублировать данное слово.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.03.2013, 21:18
Ответы с готовыми решениями:

Вывести слова, из которых нельзя составить ключевого слова, ключевое слово вводится отдельно
вывести слова из которых нельзя составить ключевого слова, ключевое слово вводится отдельно.....

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

Распечатать все слова четной длины, в которых нет удвоенной буквы Н
уважаемые эксперты помогите пожалуйста с заданием 27.1. Дана матрица размером 6Х6 элементов,...

Разбить все слова четной длины на два равных по длине слова
Разбить все слова четной длины на два равных по длине слова. Помогите с задачей, пжл)

4
-3 / 3 / 3
Регистрация: 01.03.2013
Сообщений: 34
01.03.2013, 23:20 2
Я не стану разбирать чужой код, напишу свой.
Идея такая:
1. Будем для простоты считать, что слова в строке разделены одним пробелом (можно было и со знаками препинания, но это лишь утяжелит программу).
2. Проходим по строке, выделяем слова и заносим их в массив слов b
3. Перебираем каждое слово, отбирая из них только слова чётной длины. Заносим каждое из них в дополнительную переменную r. В них сортируем буквы (не важно, по возрастанию или убыванию, главное, чтобы одинаковые буквы встали рядом).
4. Проходим по отсортированной переменной r, выбирая лишь буквы, стоящие на чётных местах и сравниваем с буквами, стоящими на нечётных местах. Если они совпадают до конца слова, то из слова можно сделать палиндром чётной длины, тогда добавляем слову такое же.
5. Распечатываем изменённый массив слов в одну строку.
Pascal
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
var
a,r:string;
t:char;
b:array[1..100]of string;
i,j,k,n,c:integer;
f:boolean;
begin
readln(a);
a:=' '+a;
for i:=1 to length(a) do
if a[i]=' ' then inc(k) else b[k]:=b[k]+a[i];
for i:=1 to k do
if length(b[i])mod 2=0 then
  begin
    r:=b[i];
     for n:=1 to length(r) do
      for j:=2 to length(r) do
       if r[j]<r[j-1] then
         begin
          t:=r[j];
          r[j]:=r[j-1];
          r[j-1]:=t;
         end;
    f:=true;
    c:=0;
    while (c<>length(r)) and (f) do
       begin
        c:=c+2;
        if r[c]<>r[c-1]then f:=false;
       end;
    if f=true then b[i]:=b[i]+' '+b[i];
    end;
for i:=1 to k do
write(b[i]+' ');
writeln;
end.
0
0 / 0 / 0
Регистрация: 01.03.2013
Сообщений: 3
02.03.2013, 01:18  [ТС] 3
Ашера, огромное Вам спасибо. А эта "идея такая"... правда ли то, что вы новичок?

Это будет грубо с моей стороны упрекнуть вас в маленькой ошибке, но в 35-ой строке точно ли нужен writeln? В самой программе он ничего не делает... если только поменять его на readln, то экран остановится и покажет видоизмененную строку. Я также думаю это будет плохой идеей просить у вас комментарий к каждой строке в программе, потому что вы все сказали в "идее такой".
0
-3 / 3 / 3
Регистрация: 01.03.2013
Сообщений: 34
02.03.2013, 01:40 4
Цитата Сообщение от NumLock Посмотреть сообщение
Ашера, огромное Вам спасибо. А эта "идея такая"... правда ли то, что вы новичок?
На этом форуме - да.
Цитата Сообщение от NumLock Посмотреть сообщение
Это будет грубо с моей стороны упрекнуть вас в маленькой ошибке, но в 35-ой строке точно ли нужен writeln?
Нет, не нужен, это писалось при отладке, чтобы данные не сливались при перезапуске.
0
0 / 0 / 0
Регистрация: 01.03.2013
Сообщений: 3
12.04.2013, 00:27  [ТС] 5
Извините за бамп старой темы... но тут появился другой вопрос. Возможно ли сделать так, чтобы отредактировалась старая строка, то есть та же, что и содержала исходные слова, без создания нового массива/строки?
0
12.04.2013, 00:27
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.04.2013, 00:27
Помогаю со студенческими работами здесь

Ввести строку. Найти все символы, входящие в слова четной длины
Ввести строку. Найти все символы, входящие в слова четной длины.

Все слова, длина которых больше в 2 раза длины слова max длины, заменить на слово min длины
подскажите пожалуйста в чем тут ошибка {Дан текст. Все слова, длина которых больше в 2 раза...

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

Распечатать все слова четной длины,
5.1. Дана матрица размером 7Х7, заполненная случайными числами от 5 до 20. Поменять местами...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Книги и учебные ресурсы по C#
InfoMaster 08.01.2025
Базовые учебники и руководства Одной из лучших книг для начинающих является "C# 10 и . NET 6 для начинающих" Эндрю Троелсена и Филиппа Джепикса . Книга последовательно раскрывает основные концепции. . .
Что такое NullReferenceEx­­­ception и как исправить?
InfoMaster 08.01.2025
NullReferenceException - одно из самых распространенных исключений, с которым сталкиваются разработчики на C#. Это исключение возникает при попытке обратиться к членам объекта (методам, свойствам или. . .
Что такое Null Pointer Exception (NPE) и как это исправить?
InfoMaster 08.01.2025
Null Pointer Exception (NPE) - это одно из самых распространенных исключений в Java, которое возникает при попытке использовать ссылку на объект, значение которой равно null. Это исключение относится. . .
Русский язык в консоли C++
InfoMaster 08.01.2025
При разработке программ на C++ одной из частых проблем, с которой сталкиваются русскоязычные программисты, является корректное отображение кириллицы в консольных приложениях. Эта проблема особенно. . .
Telegram бот на C#
InfoMaster 08.01.2025
Разработка ботов для Telegram стала неотъемлемой частью современной экосистемы мессенджеров. C# предоставляет мощный и удобный инструментарий для создания разнообразных ботов, от простых. . .
Использование GraphQL в Go (Golang)
InfoMaster 08.01.2025
Go (Golang) является одним из наиболее популярных языков программирования, используемых для создания высокопроизводительных серверных приложений. Его архитектурные особенности и встроенные. . .
Что лучше использовать при создании класса в Java: сеттеры или конструктор?
Alexander-7 08.01.2025
Вопрос подробнее: На вопрос: «Когда одновременно создаются конструктор и сеттеры в классе – это нормально?» куратор уточнил: «Ваш класс может вообще не иметь сеттеров, а только конструктор и геттеры. . .
Как работать с GraphQL на TypeScript
InfoMaster 08.01.2025
Введение в GraphQL и TypeScript В современной разработке веб-приложений GraphQL стал мощным инструментом для создания гибких и эффективных API. В сочетании с TypeScript, эта технология. . .
Счётчик на базе сумматоров + регистров и генератора сигналов согласования.
Hrethgir 07.01.2025
Создан с целью проверки скорости асинхронной логики: ранее описанного сумматора и предополагаемых fast регистров. Регистры созданы на базе ранее описанного, предполагаемого fast триггера. То-есть. . .
Как перейти с Options API на Composition API в Vue.js
BasicMan 06.01.2025
Почему переход на Composition API актуален В мире современной веб-разработки фреймворк Vue. js продолжает эволюционировать, предлагая разработчикам все более совершенные инструменты для создания. . .
Архитектура современных процессоров
inter-admin 06.01.2025
Процессор (центральный процессор, ЦП) является основным вычислительным устройством компьютера, которое выполняет обработку данных и управляет работой всех остальных компонентов системы. Архитектура. . .
История создания реляционной модели баз данных, правила Кодда
Programming 06.01.2025
Предпосылки создания реляционной модели В конце 1960-х годов компьютерная индустрия столкнулась с серьезными проблемами в области управления данными. Существовавшие на тот момент модели данных -. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru