Giter Club home page Giter Club logo

ex11's Introduction

Ex11 Создание и использование связанного списка

Поезд

Формулировка задачи

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

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

Алгоритм

Разработать алгоритм для решения задачи.

Модель поезда

Модель поезда можно представить в виде двусвязного списка, где элементами выступают вагоны (Cage)

Класс Cage выглядит так:

// класс "Вагон"
class Cage
{
    bool light; // Свет (вкл/выкл)
public:
    Cage* next; // следующий вагон
    Cage* prev; // предыдущий вагон
    Cage(): light(false), next(nullptr), prev(nullptr) {}
    void on()  { light=true;    }
    void off() { light = false; }
    bool get() const  { return light;  }
};

Начало класса Train:

class Train 
{
    Cage* first; // указатель на первый вагон
    Cage* last;  // указатель на последний вагон
    ...

Добавить в класс следующие методы:

  • конструктор (пустой поезд)
  • добавление вагона с (выключенной/включенной) лампочкой
  • печать состояния всех вагонов в поезде
  • нахождение длины поезда

Тесты

Написать несколько тестов для вычисления длины поезда (не менее 3).

Приложение

Написать демонстрационную программу с вычислением длины созданного поезда

Структура проекта

  • include/train.h - заголовочный файл для класса Train.
  • src/train.cpp - файл с реализацией методов класса.
  • src/main.cpp - домонстрационная программы для работы с функцией.

Список участников/веток

  1. Малинин Дмитрий Дмитриевич 19 ПМИ-2 b60
  2. Бакланов Алексей Александрович 19 ПМИ-2 b61
  3. Баринов Даниил Сергеевич 19 ПМИ-1 b62
  4. Богомазов Михаил Васильевич 19 ПМИ-1 b63
  5. Бугров Лев Валерьевич 19 ПМИ-1 b64
  6. Бузанов Егор Андреевич 19 ПМИ-1 b65
  7. Варлачёв Валерий Максимович 19 ПМИ-1 b66
  8. Голованов Денис Максимович 19 ПМИ-1 b67
  9. Дробот Елизавета Денисовна 19 ПМИ-1 b68
  10. Жаравина Полина Дмитриевна 19 ПМИ-1 b69
  11. Зайцев Тимур Олегович 19 ПМИ-1 b70
  12. Кабанов Денис Сергеевич 19 ПМИ-1 b71
  13. Канев Владислав Олегович 19 ПМИ-1 b72
  14. Карцева Мария Дмитриевна 19 ПМИ-1 b73
  15. Касьянов Никита Юрьевич 19 ПМИ-1 b74
  16. Козлова Дарья Андреевна 19 ПМИ-1 b75
  17. Кузнецов Михаил Дмитриевич 19 ПМИ-1 b76
  18. Лавров Артём Романович 19 ПМИ-1 b77
  19. Матвеев Андрей Сергеевич 19 ПМИ-1 b78
  20. Машанова Карина Алексеевна 19 ПМИ-1 b79
  21. Наумов Никита Александрович 19 ПМИ-1 b80
  22. Нещеткин Глеб Максимович 19 ПМИ-1 b81
  23. Пасманик Ирина Дмитриевна 19 ПМИ-1 b82
  24. Рогозян Анастасия Тимофеевна 19 ПМИ-1 b83
  25. Соболев Данил Александрович 19 ПМИ-1 b84
  26. Софронов Валерий Александрович 19 ПМИ-1 b85
  27. Трутнев Алексей Игоревич 19 ПМИ-1 b86
  28. Тумаков Вадим Сергеевич 19 ПМИ-1 b87
  29. Фролова Ольга Михайловна 19 ПМИ-1 b88
  30. Шарибжанова Диана Рашидовна 19 ПМИ-1 b89
  31. Щеникова Анна Юрьевна 19 ПМИ-1 b90
  32. Андросов Вадим Дмитриевич 19 ПМИ-2 b91
  33. Бирина Елизавета Сергеевна 19 ПМИ-2 b92
  34. Булатов Дмитрий Александрович 19 ПМИ-2 b93
  35. Демашов Никита Александрович 19 ПМИ-2 b94
  36. Добряев Иван Александрович 19 ПМИ-2 b95
  37. Дрожжачих Евгений Валерьевич 19 ПМИ-2 b96
  38. Егорова Кристина Олеговна 19 ПМИ-2 b97
  39. Загоскин Владислав Андреевич 19 ПМИ-2 b98
  40. Зарубина Ирина Михайловна 19 ПМИ-2 b99
  41. Иванов Даниил Андреевич 19 ПМИ-2 b100
  42. Клыков Антон Романович 19 ПМИ-2 b101
  43. Королев Денис Витальевич 19 ПМИ-2 b102
  44. Краюшкина Екатерина Алексеевна 19 ПМИ-2 b103
  45. Назаров Вячеслав Андреевич 19 ПМИ-2 b104
  46. Оленев Дмитрий Сергеевич 19 ПМИ-2 b105
  47. Панина Полина Сергеевна 19 ПМИ-2 b106
  48. Прыгаев Денис Алексеевич 19 ПМИ-2 b107
  49. Рогов Андрей Дмитриевич 19 ПМИ-2 b108
  50. Симонова Арина Валерьевна 19 ПМИ-2 b109
  51. Созинов Кирилл Игоревич 19 ПМИ-2 b110
  52. Титова Нина Ивановна 19 ПМИ-2 b111
  53. Уртюков Илья Алексеевич 19 ПМИ-2 b112
  54. Хорев Егор Алексеевич 19 ПМИ-2 b113
  55. Шабаршин Леонид Георгиевич 19 ПМИ-2 b114

Алгоритм выполнения работы

Для выполнения работы необходимо:

  1. Выполнить fork репозитария в свой аккаунт.
  2. Выполнить клонирование репозитария из своего аккаунта к себе на локальную машину (git clone).
  3. Создать ветку git с индивидуальным номером (git branch имя_ветки).
  4. Сделать ветку активной (git checkout имя).
  5. Необходимо разместить как исходные файлы с решениями задач, поместив cpp файлы в src, а заголовочные - в include.
  6. Добавить файлы в хранилище (git add).
  7. Выполнить фиксацию изменений (git commit -m "комментарий").
  8. Отправить содержимое ветки в свой удаленный репозитарий (git push origin имя_ветки).
  9. Создать пул-запрос в репозитарий группы и ждать результата от GitHub Actions.

ex11's People

Contributors

ashtanyuk avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.