Списки на C

C++ списки

Подскажите, в односвязном обычном списке след элемент есть NULL, в односвязном циклическом на сколько я понял след элемент будет адрес самого первого...
Но суть не в этом, как сохранять адрес самого первого элемента
Вот так в head будет всегда хранится адрес первого элемента?
Struct List
{
int num;
int *next;
int *head;
};
Т.е. к примеру сдвинуться будет
List *p;
p=p->next;
а в p->head будет адрес первого элемента списка или нет ?


Примечание:
Ну я так и делаю при заполнении, как тогда их выводить?
Пробую так:
void ShowAll(List *root)
{
do
{
printf("%d ; ",root->num);
root=root->next;
}
while(root->next!=root->head);
}
выводит все кроме последнего элемента

Примечание:
Если проверять текущий адрес, и адрес шапки после первой замены, то происходит зацикливание, получаю бесконечную кучу нулей
void ShowAll(List *root)
{
do
{
printf("%d ; ",root->num);
root=root->next;
}
while(roott!=root->head);
}

Примечание:
Если head ты подразумеваешь как указатель на список, то так нельзя, если это переменная, тогда я вообще ничего не понял
head если это указатель, будет двигаться вместе с root
Ответы:
Надеюсь поможет. мне помогло
http://www.youtube.com/watch?v=ksTiXVd-6gc


15 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

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

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.