• B правой части каждого сообщения есть стрелки и . Не стесняйтесь оценивать ответы. Чтобы автору вопроса закрыть свой тикет, надо выбрать лучший ответ. Просто нажмите значок в правой части сообщения.

  • 15 апреля стартует «Курс «SQL-injection Master» ©» от команды The Codeby

    За 3 месяца вы пройдете путь от начальных навыков работы с SQL-запросами к базам данных до продвинутых техник. Научитесь находить уязвимости связанные с базами данных, и внедрять произвольный SQL-код в уязвимые приложения.

    На последнюю неделю приходится экзамен, где нужно будет показать свои навыки, взломав ряд уязвимых учебных сайтов, и добыть флаги. Успешно сдавшие экзамен получат сертификат.

    Запись на курс до 25 апреля. Получить промодоступ ...

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

  • Автор темы Kilin
  • Дата начала
K

Kilin

Нужно написать программу которая проверяет зеркально ли введенное слова.Если введено зеркальное слова выводит "YES",если нет выводит "NO".Например вводим abba выводит "YES",вводим massa выводит "NO" .Зеркальные слова читаются одинаково и справа и слева.
 
D

DarkKnight

Сравнить все символы...

Вот пример с помощью указателей
C++:
#include <iostream>

using namespace std;

void main (void)
{
char buffer[1024]; //Буферная переменная в нее получим строку
setlocale (LC_ALL,"Russian"); //Локаль... сугубо для отображенияв Win32 консоли кириллицы
cout<<"Введите строку : "; //Диалог ввода строки
gets(buffer); //Получим строку

char *start = buffer; //Указатель на начало строки
char *end = &buffer[strlen(buffer)-1]; //Указатель на конец строки (исключая завершающий символ строки)
// Либо так //char *end = buffer + strlen(buffer)-1;
bool mirror = true; //Идем от противного, предположим что слово (строка) зеркально
for (int i = 0; i< strlen(buffer); i++) //Обойдем строку
{
if (*start != *end) //Если символы не равны то наше предположение не верно
{
mirror = false; //Присвоим false
break; //Выйдим из цикла заранее
}
start++; //Сдвини начало на один байт в строну конца (было abba - стало bba)
end--; //Сдвиним конец на один байт в сторону начала (было a - ba)
}

if (mirror) //Вывод на экран
cout<<"YES";
else cout<<"NO";
}

Вот пример тоже самое, но обращение к строке как к массиву
C++:
	bool mirror = true; //Идем от противного, предположим что слово (строка) зеркально
for (int i = 0; i< strlen(buffer); i++) //Обойдем строку
{
if (buffer[i] != buffer[strlen(buffer)-1-i]) //Если символы не равны то наше предположение не верно
{
mirror = false; //Присвоим false
break; //Выйдим из цикла заранее
}
}

if (mirror) //Вывод на экран
cout<<"YES";
else cout<<"NO";
 
Мы в соцсетях:

Обучение наступательной кибербезопасности в игровой форме. Начать игру!