односвязный циклический список

компьютеры программирование

Поясните, в чем проблема, работает не так как надо
void Add(List **root,int *k)
{

List *tmp=(List*)malloc(sizeof(List));
List *p;
printf("Enter number ");
scanf("%d",&(tmp->num));
if((*k)==0)
{
(*k)++;
tmp->next=tmp;
*root=tmp;
}
else
{
int i=0;
List *p=*root;
while(i<(*k))
{
*root=(*root)->next;
i++;
}
tmp->next=p;
(*root)=tmp;
(*k)++;
}
}
Это функция добавления записи
сама структура
struct List
{
int num;
List *next;
};

Примечание:
количество элементов в списке
Ответы:
А зачем параметр "k" нужен?
#
И это плохая идея в одной функции совмещать ввод/вывод и добавление элемента в список.
Кстати определение структуры некоректное:
struct List {
       int num;
       struct List *next;
};


14 лет назад

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

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

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