С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.80/40: Рейтинг темы: голосов - 40, средняя оценка - 4.80
101 / 101 / 27
Регистрация: 10.09.2010
Сообщений: 267

Стек и произвольный доступ

27.04.2011, 04:08. Показов 8776. Ответов 25
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
dederkay, то что вы делается сложно назвать стеком. Это больше похоже на список. Точнее это и есть список. Одним из главных свойств стека является то что элементы расположенных в памяти непосредственно друг за другом.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.04.2011, 04:08
Ответы с готовыми решениями:

Произвольный доступ к строкам
правильно ли я понимаю что в c++ нет функции "прочитать из файла строку номер ..." ? как её можно реализовать попроще?

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

Поиск и произвольный доступ внутри файла
Всем привет! Допустим есть текстовый файл, выглядит так: ____________________________________________________ C8-0C-C8 ...

25
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
27.04.2011, 04:51
Цитата Сообщение от dederkay Посмотреть сообщение
<тип> operator [] (int i)
Это у массивов, должно искать i-тый элмент и возвращать на него ссылку, а у тебя стек, к нему запрешён произвольный доступ по индексу.
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
27.04.2011, 11:39
Цитата Сообщение от Overmind024 Посмотреть сообщение
Одним из главных свойств стека является то что элементы расположенных в памяти непосредственно друг за другом.
Нет. Расположение в памяти не имеет никакого значения.
0
27.04.2011, 11:41

Не по теме:

Цитата Сообщение от Overmind024 Посмотреть сообщение
Одним из главных свойств стека является то что элементы расположенных в памяти непосредственно друг за другом.
А ну-ка быстро учить, что такое стек! :rtfm:
:D

1
101 / 101 / 27
Регистрация: 10.09.2010
Сообщений: 267
27.04.2011, 22:31  [ТС]
Ну тогда чем же этот стек отличается от списка?? Названием методов(не add, а push)???
И я не разу не встречал стек не похожий на массив. Откуда же тогда взялось понятие переполнение стека(оперативная память что ли закончилась)??
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
27.04.2011, 22:41
Overmind024, стек - это структура данных, никакого отношения ни к памяти, ни к аппаратным или программным реализациям не имеющая. Она не знает, что такое память, что она может закончится и т.д. Как, впрочем, и список. Фишка стека в том, что он не имеет произвольного доступа к элементам. Как заталкивать в него элементы, так и доставать их из него можно только с одного конца. Всё, на этом особенности стека заканчиваются. Как реализуете его вы - массивом, списком или ещё как - это чисто ваш выбор. Единственное требование - должны сохраняться свойства стека, иначе стеком ваша писанина называться не будет (преподы любят давать задания типа "реализовать стек, переопределить операцию доступа по индексу". Слава Богу, у меня подобные личности предметов не вели).
0
 Аватар для kazak
3601 / 2742 / 355
Регистрация: 11.03.2009
Сообщений: 6,300
27.04.2011, 23:52
silent_1991, а где это определено, что стек ни при каких обстоятельствах не может иметь произвольный доступ?
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
28.04.2011, 00:22
Стек (англ. stack — стопка) — структура данных, в которой доступ к элементам организован по принципу LIFO (англ. last in — first out, «последним пришёл — первым вышел»).
0
 Аватар для kazak
3601 / 2742 / 355
Регистрация: 11.03.2009
Сообщений: 6,300
28.04.2011, 01:54
Это мне известно, но всетаки что мешает сделать произвольный доступ? И как тогда именовать системный стек?
0
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
28.04.2011, 02:05
Цитата Сообщение от kazak Посмотреть сообщение
Это мне известно, но всетаки что мешает сделать произвольный доступ? И как тогда именовать системный стек?
Простите, Вы шутите? Вы серьезно не знаете, что такое стек? Может мне опять картинки начать рисовать?
Какой еще произвольный доступ в стеке? Произвольный доступ предполагает, что можно обратиться к любому элементу за время O(1), то есть константа, постоянное время. В стеке же вообще обратиться можно только к одному элементу, и здесь уже не важно как устроен стек: node- или array-based или еще что-нибудь. Главное что доступ есть только к одному элементу. В стеке нельзя осуществлять поиск элемента, вставку в середину... иначе это уже не стек...
Где логика и смысл Ваших высказываний?
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
28.04.2011, 02:11
kazak, на некотором уровне абстракции стек - структура данных, которая позволяет складывать элементы на стек, и снимать их с его верхушки (за один раз - один элемент). Тут просто не может быть других вариантов. Просто напросто структура данных с возможностью складывать элементы и снимать их с верхушки, но ещё и с произвольным доступом, стеком являться не будет. И даром, что лифо там тоже есть.
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
28.04.2011, 05:57
Цитата Сообщение от fasked Посмотреть сообщение
Произвольный доступ предполагает, что можно обратиться к любому элементу за время O(1), то есть константа, постоянное время
Ничего подобного. Произвольный доступ предполагает доступ к элементу по его индексу. Всё, точка.

Цитата Сообщение от kazak Посмотреть сообщение
но всетаки что мешает сделать произвольный доступ?
Повторяю, ЭТО называется Вектор.
0
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
28.04.2011, 09:24
Цитата Сообщение от Deviaphan Посмотреть сообщение
Произвольный доступ предполагает доступ к элементу по его индексу.
А по-моему произвольный доступ предполагает доступ к любому элементу без необходимости разрушающего доступа к другим элементам. А по индексу или путём указания какой то иной уникальной для каждого элемента информации - вопрос второстепенный. В реляционных БД для этого используется первичный ключ, в многомерных массивах - комбинация такого количества индексов, какова размерность массива. Да и иттераторы - не совсем индексы.
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
28.04.2011, 10:47
Цитата Сообщение от taras atavin Посмотреть сообщение
А по индексу или путём указания какой то иной уникальной для каждого элемента информации - вопрос второстепенный.
Под словом "индекс" я подразумевал не переменную типа size_t, а как раз уникальный ключ. Одно это число или комбинация строк - не существенно.

Цитата Сообщение от taras atavin Посмотреть сообщение
В реляционных БД...
БД и контейнер это немного разные сущности.

Цитата Сообщение от taras atavin Посмотреть сообщение
Да и иттераторы - не совсем индексы
Итераторы - совсем не индексы. По определению. Они предназначены для последовательного обхода контейнера. Ничего общего с произвольным доступом итераторы не имеют.

Цитата Сообщение от taras atavin Посмотреть сообщение
по-моему произвольный доступ предполагает доступ к любому элементу без необходимости разрушающего доступа к другим элементам.
Нет. Доступ к элементам списка так же не вызывает разрушения других элементов списка, но ничего общего с произвольным доступом не имеет.
0
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
28.04.2011, 11:06
Цитата Сообщение от Deviaphan Посмотреть сообщение
Ничего подобного. Произвольный доступ предполагает доступ к элементу по его индексу. Всё, точка.
Я могу в собственном классе связного списка завести переменную типа size_t и перегрузить operator[], но от этого random access в данной структуре не появится. То есть я конечно понимаю, что Вы хотите сказать (надеюсь, что понимаю). Но формулировка с индексом ой как не точна.
Цитата Сообщение от taras atavin Посмотреть сообщение
А по-моему произвольный доступ предполагает доступ к любому элементу без необходимости разрушающего доступа к другим элементам. А по индексу или путём указания какой то иной уникальной для каждого элемента информации - вопрос второстепенный. В реляционных БД для этого используется первичный ключ, в многомерных массивах - комбинация такого количества индексов, какова размерность массива. Да и иттераторы - не совсем индексы.
А здесь вообще полный бред написан. Итераторы - это совсем не индексы, это уж скорее указатели, чем индексы Деструктивное воздействие? Вы бы хотя бы википедию открыли прежде, чем начинать спорить..

Ужас какой-то
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
28.04.2011, 11:14
Цитата Сообщение от fasked Посмотреть сообщение
Произвольный доступ предполагает доступ к элементу по его индексу.
*за постоянное время
.)
0
28.04.2011, 11:16

Не по теме:

Цитата Сообщение от Deviaphan Посмотреть сообщение
за постоянное время
О чем я и сказал ;)

0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
28.04.2011, 11:26
Цитата Сообщение от fasked Посмотреть сообщение
О чем я и сказал
Да-да, я помню. Это я как бы делаю вид, что я не тупил, а прям сразу согласен и был.)
0
 Аватар для taras atavin
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
28.04.2011, 11:29
Цитата Сообщение от Deviaphan Посмотреть сообщение
БД и контейнер это немного разные сущности.
Да, но понятие доступа от этого не зависит.

Добавлено через 50 секунд
Цитата Сообщение от Deviaphan Посмотреть сообщение
Итераторы - совсем не индексы. По определению. Они предназначены для последовательного обхода контейнера. Ничего общего с произвольным доступом итераторы не имеют.
Да, действительно бред сморозил.
0
 Аватар для kazak
3601 / 2742 / 355
Регистрация: 11.03.2009
Сообщений: 6,300
28.04.2011, 13:05
Цитата Сообщение от silent_1991 Посмотреть сообщение
на некотором уровне абстракции
беда в том, что вы эти абстракции воспринимаете чересчур буквально, идеализированно.
Возьмем системный стек, с которым работает процессор. Процессор использует две команды для работы со стеком: push/pop - поместить в стек/вытолкнуть из стека. Поиска как такового нет, вставить в середину стека тоже нельзя, как и удалить из середины. Вроде как все по определению, но при работе со стеком используются два указателя: регистр ESP (текущая вершина стека) с которым непосредственно работают push/pop и регистр EBP (так называемый указатель кадра стека), который используется в частности для обращения к аргументам и локальным переменным вызываемых функций, причем эти переменные могут находится довольно далеко от текущей вершины стека. Т.е. фактически имеем стек с возможностью произвольного доступа, но даже с этой возможностью вся эта "система" остается "стеком" в том числе и в понятии вашего уровня абстракции.

Цитата Сообщение от fasked Посмотреть сообщение
Вы бы хотя бы википедию открыли
википедия конечно довольно познавательный ресурс, но на роль "авторитетного источника" не тянет.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.04.2011, 13:05
Помогаю со студенческими работами здесь

Произвольный доступ к файлу большого размера 4+гб
Предыстория. Поверхностно изучил файлы и пошел дальше, потом решил вернуться и изучить все глубоко. Все в голове поломалось, когда я понял,...

Произвольный доступ в файл. Лишний символ новой стоки
Здравствуйте, помогите разобратся. #include &lt;iostream&gt; #include &lt;fstream&gt; using namespace std; int main(){ ifstream...

Произвольный доступ к структуре в памяти(любой), C++
Суть в чём: Есть какая-либо структура данных, к примеру struct struct_t { int data1; int data2; char arr; } В случае...

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

Стек. Создать случайно генерированный стек и поменять местами первый элемент с i
Как создать случайно генерированный стек (тип элементов CHAR) и поменять местами первый элемент с i (i - вводит пользователь)?


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru