Форум программистов, компьютерный форум, киберфорум
Haskell
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/15: Рейтинг темы: голосов - 15, средняя оценка - 4.93
0 / 0 / 0
Регистрация: 18.12.2014
Сообщений: 20

Проверить, является ли строка палиндромом

29.05.2015, 18:39. Показов 3329. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Проверить, является ли строка полиномом палиндромом
(читается одинаково задам-наперед)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.05.2015, 18:39
Ответы с готовыми решениями:

Проверить является ли строка e-mail
Проверить является ли введенная строка e-mail. Без усложнений, то есть просто вида *@*.* С минимальными комментами по коду, если не...

[Кумир] Ввести символьную строку и проверить является ли она палиндромом.
ввести символьную строку и проверить является ли она палиндромом На кумир

Проверить, является ли строка палиндромом
программа проверяет ОДНО слово на палиндром, а как сделать чтобы она работала с пробелами? var S: string; i: Integer; ...

7
Диванный эксперт
Эксперт С++
 Аватар для Max Dark
2550 / 2064 / 971
Регистрация: 09.10.2013
Сообщений: 4,793
Записей в блоге: 4
29.05.2015, 18:49
Haskell
1
2
3
some::String->Bool
some s = (reverse s) == s
main = print $ show $ some "abx"
1
0 / 0 / 0
Регистрация: 18.12.2014
Сообщений: 20
29.05.2015, 19:43  [ТС]
Забыл уточнить, БЕЗ использования reverse
0
202 / 200 / 65
Регистрация: 06.10.2013
Сообщений: 552
29.05.2015, 21:00
Ну так напишите свой reverse. Например, так:
Haskell
1
2
3
rev []  = []
rev [x] = [x]
rev x   = (rev $ tail x) ++ [head x]
2
Модератор
 Аватар для Curry
5158 / 3486 / 536
Регистрация: 01.06.2013
Сообщений: 7,562
Записей в блоге: 9
29.05.2015, 21:21
Не полином, а палиндром это называется.
Haskell
1
2
3
4
5
6
7
8
palindrome :: String -> Bool
palindrome [] = True
palindrome [x] = True
palindrome (x:xs)
   | x == last xs = palindrome $ init xs
   | otherwise = False
   
main = print $ palindrome "арозаупаланалапуазора"
1
Модератор
Эксперт функциональных языков программирования
3136 / 2283 / 469
Регистрация: 26.03.2015
Сообщений: 8,886
29.05.2015, 21:44
Добавлено через 12 минут
KolodeznyDiver,
На каждом шаге мы будем весь список пробегать 2 раза (для last и для init)?
Выглядит неэффективно.
0
Модератор
 Аватар для Curry
5158 / 3486 / 536
Регистрация: 01.06.2013
Сообщений: 7,562
Записей в блоге: 9
29.05.2015, 22:27
Цитата Сообщение от Shamil1 Посмотреть сообщение
На каждом шаге мы будем весь список пробегать 2 раза (для last и для init)?
Выглядит неэффективно.
Да. Не эффективно. С reverse быстрее. Но если такие учебные задачи задают. И не факт что самодельный reverse прокатит. Использование двухнаправленного списка (Data.Sequence) тоже врят ли прокатит.

Добавлено через 24 минуты
Можно ещё так
Haskell
1
2
palindrome :: Eq a => [a] -> Bool
palindrome s = fst $ foldr (\a (r, b:bx) -> (r && a==b,bx)) (True,s) s
1
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38180 / 21115 / 4307
Регистрация: 12.02.2012
Сообщений: 34,722
Записей в блоге: 14
30.05.2015, 07:21
Наверняка "пафос" задачи в том, чтобы отсечь очевидное решение (с reverse) и использовать простую рекурсию. Напр. так:

Haskell
1
2
3
4
isPal :: String -> Bool
isPal ""    = True
isPal [x]  = True
isPal x    = (head x)==(last x) && (isPal $ drop 1 $ init x)
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
30.05.2015, 07:21
Помогаю со студенческими работами здесь

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

Проверить является ли строка палиндромом
функция проверяет,является ли передаваемая строка палиндромом?

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

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

Проверить, является ли строка палиндромом
Возможно я не первый кто просит помочь в данной задачи, но все же повторюсь. Задание: Проверить является ли строка палиндромом....


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru