Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RFpro.ru: Программирование на C / C++


Хостинг портала RFpro.ru:
Московский хостер
Профессиональный ХОСТИНГ на базе Linux x64 и Windows x64

РАССЫЛКИ ПОРТАЛА RFPRO.RU

Чемпионы рейтинга экспертов в этой рассылке

Гаряка Асмик
Статус: Специалист
Рейтинг: 3360
∙ повысить рейтинг »
lamed
Статус: Бакалавр
Рейтинг: 2403
∙ повысить рейтинг »
Boriss
Статус: Академик
Рейтинг: 2173
∙ повысить рейтинг »

/ КОМПЬЮТЕРЫ И ПО / Программирование / C/C++

Номер выпуска:1521
Дата выхода:29.04.2010, 20:30
Администратор рассылки:Verena, Профессионал
Подписчиков / экспертов:494 / 177
Вопросов / ответов:1 / 1
IRC-канал по теме:#C

Вопрос № 178017: Можете пожалуйста написать программу заново, или полностью исправить, если удасться, готовый код с ошибками Условие: Дана последовательность, имеющая от 2 до 50 слов, в каждом из которых от 1 до 8 рядковых латинских букв, между соседними словам...



Вопрос № 178017:

Можете пожалуйста написать программу заново, или полностью исправить, если удасться, готовый код с ошибками
Условие:
Дана последовательность, имеющая от 2 до 50 слов, в каждом из которых от 1 до 8 рядковых латинских букв, между соседними словами не меньше одного пропуска, за последним словом - точка. Напечатать те слова последовательности, которые отличаються от последнего слова и включают способность: слово симетричное

Отправлен: 24.04.2010, 20:16
Вопрос задал: Альохин Сергей Геннадиевич, Посетитель
Всего ответов: 1
Страница вопроса »


Отвечает Alex_S, 8-й класс :
#include <iostream>

using namespace std;

bool IsSimmetric(char*);
int GetLastWord(char*,char*);

//---------------------------

int main(void)
{
char st[1000];
char last_word[32];


//ввод строки
cin.getline(st, 1000);

//получить последнее слово
GetLastWord(st, last_word);

char * p = strtok(st, " .");

while ( p )
{
if ( strcmp(p, last_word) && IsSimmetric(p) )
{
cout << p << endl;
}

p = strtok(NULL, " .");
}

return 0;
}

//---------------------------

bool IsSimmetric(char* st)
{
int n = strlen(st);

for (int i=0; i < n/2; i++)
{
if ( st[i] != st[n-i-1] )
{
return false;
}
}

return true;
}

//---------------------------

int GetLastWord(char* input_str, char* last_word_str)
{
char* dot;


//найти т очку в строке
dot = strchr(input_str, '.');

//найти начало последнего слова
for (int i=-1; dot[i] != ' '; i--);

i++;

//скопировать последнее слово
memcpy(last_word_str, dot+i, -i);

//нулевой терминатор
last_word_str[-i] = '\0';

return -i;
}

-----
йо-хо-хо!

Ответ отправил: Alex_S, 8-й класс
Ответ отправлен: 24.04.2010, 21:47
Номер ответа: 260995

Оценка ответа: 5

Вам помог ответ? Пожалуйста, поблагодарите эксперта за это!
Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 260995 на номер 1151 (Россия) | Еще номера »
  • Отправить WebMoney:

  • Оценить выпуск »
    Нам очень важно Ваше мнение об этом выпуске рассылки!

    Задать вопрос экспертам этой рассылки »

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров »

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2010, Портал RFpro.ru, Россия
    Авторское право: ООО "Мастер-Эксперт Про"
    Автор: Калашников О.А. | Программирование: Гладенюк А.Г.
    Хостинг: Компания "Московский хостер"
    Версия системы: 2010.6.14 от 03.03.2010

    В избранное