Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
14 / 14 / 2
Регистрация: 03.01.2011
Сообщений: 77

ООП

01.08.2011, 23:31. Показов 1394. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите статью или книгу где рассказывается про динамические списки (с указателями,ссылками,динамической памятью и классами знаком)
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.08.2011, 23:31
Ответы с готовыми решениями:

C++ ООП
Просьба дать какую-нибудь интересную программу, дабы теста на курс ООП. Чтобы не из книжки, а реально придуманная про программистом, или...

ООП
Привет всем, народ дайте какую-нибудь интересную задачку на ООП, (однообразные задачи из учебников достали уже), чтоб она затрагивала как...

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

10
Каратель
Эксперт С++
6610 / 4029 / 401
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
01.08.2011, 23:32
Седжвик - Фундаментальные алгоритмы на С++
0
Заблокирован
01.08.2011, 23:40
Практически, в любой книге по С++ эта тема затрагивается, так как в С++ есть стандартно определенные контейнеры типа вектор, список, дека.
Есть отдельные книги, как, например, Уильям Дж.Коллинз "Структуры данных и стандартная библиотека шаблонов"
0
 Аватар для alkagolik
1599 / 622 / 113
Регистрация: 15.07.2011
Сообщений: 3,548
02.08.2011, 01:41
юзай поиск "динамические структуры данных" хорошая ссылочка. Я так подразумеваю что пользовать STL нельзя, а если можно то читай STL там реализованы списки, очереди, стеки.
0
Android Programmer
141 / 142 / 10
Регистрация: 08.12.2010
Сообщений: 421
02.08.2011, 01:43
alkagolik, перед тем как начать их пользовать, все же стоит разобраться, и понимать как оно работает.
0
 Аватар для alkagolik
1599 / 622 / 113
Регистрация: 15.07.2011
Сообщений: 3,548
02.08.2011, 01:47
silentnuke
Именно поэтому я и уточнил. В ссылке, которую я дал, хорошо все описано без использования STL.
0
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
02.08.2011, 01:49
Цитата Сообщение от alkagolik Посмотреть сообщение
хорошая ссылочка
Пролистал, стошнило на третьей странице.
0
 Аватар для Roof
155 / 155 / 44
Регистрация: 03.11.2010
Сообщений: 393
02.08.2011, 01:54
2 fasked - поясните подробно, если не затруднит.
0
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
02.08.2011, 02:18
Лучший ответ Сообщение было отмечено как решение

Решение

Цитата Сообщение от Roof Посмотреть сообщение
поясните подробно, если не затруднит.
Я сейчас приведу несколько цитат из статьи, которые бросились мне в глаза и показались совершенно некомпетентными.

Страница первая.
Начнем с того, что автор предлагает использовать следующую структуру для узла списка. Стоит уточнить, что в статье "узел" автор называет "звеном", мне привычнее говорить и писать "узел", поэтому я буду и дальше так говорить, но стоило упомянуть об этом, чтобы не возникало недопониманий.
C++
1
2
3
4
5
struct node
    {
      int elem; //Информационный элемент звена списка 
      node *sled; // Указатель на следующее звено списка 
    };
Бросается в глаза использование транслита - этого я никогда не одобрял, да и не буду, неправильно использовать такие имена. Правда, справедливости ради, на следующей странице автор исправился. Еще может использование модификатора доступа public для данных не совсем правильно, но тут нужен контекст, в отрыве от него сложно сказать. Все это можно списать на то, что читатель скорее всего имеет уровень начинающего, да пусть будет так.

Следующий абзац на этой же странице гласит: "Чтобы иметь возможность оперировать со списком как с единым объектом, введем в употребление статическую ссылочную переменную phead, которая указывает на первое звено списка..."
Ключевое слово здесь - статическую. То есть получается, что пользователь не сможет создать несколько списков, так как переменная (указатель на голову списка) статическая. Это ужасно. Однако, сам код, который продемонстрировал автор, не содержит ни ключевого слова static, и указания на то, что объект объявлен в глобальном пространстве имен.

Страница вторая
На этом шаге мы рассмотрим построение списка без заглавного звена.
Что значит без заглавного звена? Как вообще можно манипулировать списком без указателя на его начало? Это осталось для меня тайной, так как в следующем же примере, автор использует указатель на голову списка. Может быть я неправильно понимаю слово "заглавный".
Дальше эту страницу я уже не читал. Так как текст попахивал полной ахинеей.

Страница третья.
Построение списка с заглавным звеном.
Увидел, что автор ссылается на Д. Кнута - посмеялся. Далее мой взгляд упал на код.
C++
1
2
(*t).sled = NULL;
(*t).sled = new (node);
И в том же духе. Нахрена, спрашивается, разыменовывать указатель. Автор не знает, что существует оператор доступа -> ?
C++
1
t->sled = NULL;
В первой части описывается алгоритм добавления элемента, насколько я понял. Стошнило меня, однако, на этом моменте.
C++
1
void POSTROENIE (node **phead)
После прочтенного, я позволю себе сделать выводы и небольшую аннотацию.
Может быть, автор вполне представляет себе, что такое списки. Он даже нарисовал довольно много картинок, что подверждает это предположение. Однако, объяснено все слишком грубо. Автор искрит терминологией собственного производства, которая многим может быть непонятна или введет новичков в заблуждение.
Относительно программирования вообще беда. На первой же странице читателю сообщается, что код будет написан на C++, однако, из C++ кода я заметил только использование new для выделения памяти. Автор пишет в стиле Си. Нет ни классов, ни методов, ни инкапсуляции.
При реализации списка, сам список не был представлен как отдельная сущность. Автор оперирует узлами списка, как беспорядочными объектами.
Автор не следует стандартам языка, то есть он объявляет функцию main с типом void. Кстати, вся выделенная память не освобождается.
Можно даже предположить, что автор пересел с какого-нибудь бэйсика или паскаля. Обучался программированию в шараге на динозавре Borland C++ 3.1 или чем-то подобном. А потом заимев ЧСВ более 9000 бросился писать статейки о программировании. Противоречит сам себе во многих местах.

Вердикт: не читать, ни в коем случае!
6
 Аватар для Roof
155 / 155 / 44
Регистрация: 03.11.2010
Сообщений: 393
02.08.2011, 02:59
2 fasked - уважаю обоснованную критику, спасибо за пояснения.
0
377 / 228 / 79
Регистрация: 24.11.2009
Сообщений: 695
02.08.2011, 21:23
внесу свои пять копеек:
алголист.ру.
Дональд Кнут 1 том.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.08.2011, 21:23
Помогаю со студенческими работами здесь

ООП на С++
Помогите пожалуйста!! Не понимаю как это сделать(( Создать программу с классом Student порождающий обьекты - данные об студентах...

по ООП .
Помогите пожалуйтса с решением задач ! на С++ 1.Дана неубывающая последовательность действительных чисел. Вставить в неё...

ООП
Доброго времени суток. Хотелось бы получить совет по поводу следующего. Имеется базовый класс class Base { public: virtual...

ООП
Господа у меня возникло 2 вопроса по ООП т.к. только не давно начал его изучать . 1) Не как не могу понять для чего умные люди его...

ООП в С++
Здравствуйте! Ответьте пожалуйста на несколько вопросов... p.s. буду рад , если ответы будут сопровождаться примерами :) Хочу...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru