Каким образом можно убрать (упростить) while?

Компьютеры программирование C++ cpp

typedef struct q{ int d; q*next } el;
el *head = NULL;
void AddTail (int d1){
if (head==NULL) {head.d=d1; head->next=NULL;}
else{while(head->next){head=head->next;}
head->next=new el;
head=head->next;
head->d=d1;
head->next=NULL;}

Код написанный выше равнозначен push из контейнера Queue (элементы добавляются в конец). Помогите пожалуйста упростить его так, что бы не было while.

Примечание:
Получается я должен найти последний

Примечание:
элемент до того начинаю проверять на первый?
Ответы:
или использовать цикл или хранить адрес последнего элемента в еще одной переменной


12 лет назад

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

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

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