gif
Портал edu4cash: Что это и как работает?.
gif
Как быстро получить ответ от ИИ.
gif
Как задонатить в Roblox в России в 2024 году.
gif
Обновления на edu4cash – новые награды, улучшенная модерация и эксклюзивные возможности для VIP!.
  • Задать вопрос
  • Назад
  • Главная страница
  • Вопросы
  • Предметы
    • Русский язык
    • Литература
    • Математика
    • Алгебра
    • Геометрия
    • Вероятность и статистика
    • Информатика
    • Окружающий мир
    • География
    • Биология
    • Физика
    • Химия
    • Обществознание
    • История
    • Английский язык
    • Астрономия
    • Физкультура и спорт
    • Психология
    • ОБЖ
    • Немецкий язык
    • Французский язык
    • Право
    • Экономика
    • Другие предметы
    • Музыка
  • Темы
  • Банк
  • Магазин
  • Задания
  • Блог
  • Топ пользователей
  • Контакты
  • VIP статус
  • Пригласи друга
  • Донат
  1. edu4cash
  2. Вопросы
  3. Информатика
  4. 11 класс
  5. Условие задачи: Дана непустая последовательность непустых слов из латинских букв; соседние слова отделены друг от друга запятой, за последним словом – точка. Необходимо определить количество слов, которые начинаются и заканчиваются одной и той же букво...
Задать вопрос
Похожие вопросы
  • Посчитайте элементы последовательности
  • Как можно решить задачу о запасе рыбы в пруду, если известны начальный запас А тонн, ежегодный прирост 15%, план отлова B тонн и минимальный запас С тонн, при этом нужно составить блок-схему алгоритма для подсчёта количества лет, в течение которых можн...
  • В компании работает 424 человека. На входе в их здание стоит турникет, считывающий номера карт работников и фиксирующий время прохода. Устройство записывает его номер (от 1 до 424) и время прохода (например, 23 : 55, при этом часы - это число от 0 до 2...
  • Кот Матроскин и пёс Шарик нашли клад, который состоял из 5 одинаковых монт. В коробке, в которой лежали монеты, друзья обнаружили записку: "При помощи чашечных весов без гирь найдите среди этих 5 монет одну золотую и купите почтальону Печкину велосипед...
  • Документ (без упаковки) можно передать по каналу связи с одного компьютера на другой за 1 минуту 30 секунд. Если предварительно упаковать документ архиватором, передать упакованный документ, а потом распаковать на компьютере получателя, то общее время...
barry.harris

2025-02-01 22:04:20

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

Код:

Program stroka;
Var
s:String;
i,k:Integer;
c:char;

Begin

ReadLn(s);
c:=s[1];
For i:=1 To Length(s) Do
begin
if (((s[i]=',') or (s[i='.'])) and (s[i-1]=c)) then
begin
inc(k);
c:=s[i+1];
end;
end;
writeln(k);
readln;
End.

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

Информатика 11 класс Алгоритмы и структуры данных информатика 11 класс задача на слова программирование Pascal количество слов буквы алгоритмы последовательность слов исправление кода логика программы Новый

Ответить

Born

2025-02-01 22:04:29

Давайте разберем вашу задачу и код, который вы представили. Ваша цель — определить количество слов в последовательности, которые начинаются и заканчиваются одной и той же буквой. Код, который вы написали, действительно имеет несколько недостатков, из-за которых он работает некорректно. Мы исправим его шаг за шагом.

1. Анализ кода:

В вашем коде есть несколько ключевых ошибок:

  • Переменная c инициализируется первой буквой строки, что неправильно, так как она должна представлять последнюю букву каждого слова.
  • Переменная k не инициализирована, что может привести к неопределенному поведению.
  • Цикл проходит по всем символам строки, но не учитывает, что слова могут содержать более одной буквы.

2. Исправление кода:

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

  1. Сначала мы инициализируем переменные.
  2. Будем использовать цикл для чтения каждого слова.
  3. Проверим, начинается ли слово и заканчивается ли оно одной и той же буквой.
  4. Если да, увеличим счетчик.

Вот исправленный код:

Program stroka;
Var 
    s: String;
    i, k: Integer;
    word: String;
Begin
    ReadLn(s);
    k := 0; // Инициализируем счетчик
    word := ''; // Переменная для хранения текущего слова

    // Проходим по каждому символу строки
    For i := 1 To Length(s) Do
    begin
        // Если символ не запятая и не точка, добавляем его к текущему слову
        if (s[i] <> ',') and (s[i] <> '.') then
            word := word + s[i]
        else
        begin
            // Если слово не пустое, проверяем его
            if word <> '' then
            begin
                // Проверяем, начинается и заканчивается ли слово одной и той же буквой
                if word[1] = word[Length(word)] then
                    inc(k); // Увеличиваем счетчик
            end;
            // Сбрасываем текущее слово
            word := '';
        end;
    end;

    // Проверяем последнее слово (если оно есть)
    if word <> '' then
    begin
        if word[1] = word[Length(word)] then
            inc(k);
    end;

    writeln(k); // Выводим результат
    readln;
End.

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

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


barry.harris ждет твоей помощи!

Ответь на вопрос и получи 36 Б 😉
Ответить

  • Политика в отношении обработки персональных данных
  • Правила использования сервиса edu4cash
  • Правила использования файлов cookie (куки)

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

Copyright 2024 © edu4cash

Получите 500 балов за регистрацию!
Регистрация через ВКонтакте Регистрация через Google

...
Загрузка...
Войти через ВКонтакте Войти через Google Войти через Telegram
Жалоба

Для отправки жалобы необходимо авторизоваться под своим логином, или отправьте жалобу в свободной форме на e-mail [email protected]

  • Карма
  • Ответов
  • Вопросов
  • Баллов
Хочешь донатить в любимые игры или получить стикеры VK бесплатно?

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

Баллы легко обменять на донат, стикеры VK и даже вывести реальные деньги по СБП!

Подробнее