У меня есть следующий код я "м преобразование строки, хранящейся в связанном списке . Пример: ABC A-> B-> C-> NULLСтрока связанного списка, используя двойной указатель
Проблемы : При печати списка, это не дает желаемого output.Following является код и примеры входы/выходы
код
#include<stdio.h>
#include<stdlib.h>
typedef struct node
{
char ch;
struct node *next;
}node;
void create(node **head,char ch)
{
node *new;
new=malloc(sizeof(node));
new->next=NULL;
new->ch=ch;
if(*head==NULL)
{
*head=new;
printf("%c",(*head)->ch);
return ;
}
while((*head)->next)
{
(*head)=(*head)->next;
}
(*head)->next=new;
}
void printList(node *head)
{
printf("\nThe list has - ");
while(head)
{
printf("%c",head->ch);
head=head->next;
}
printf("\n\n");
}
int main()
{
node *head=NULL;
int i=0;
char *str=NULL;
str=malloc(sizeof(char)*15);
printf("\nEnter the string - ");
scanf("%s",str);
while(str[i]!='\0')
{
create(&head,str[i]);
i++;
}
printList(head);
return 0;
}
.
Пример ввода/выходы
вход 1
Enter the string - abc
a
The list has - bc
вход 2
Enter the string - abcde
a
The list has - de
вход 3
Enter the string - ab
a
The list has - ab
Примечание:
Если изменить мои функции создания этого, все работает отлично !. Я хочу знать, в чем тут разница? Это как-то связано с двойной стрелкой?
void create(node **head,char ch)
{
node *new,*ptr;
new=malloc(sizeof(node));
new->next=NULL;
new->ch=ch;
ptr=*head;
if(ptr==NULL)
{
ptr=new;
return;
}
while(ptr->next)
{
ptr=ptr->next;
}
ptr->next=new;
}
Спасибо!
Вы не описываете желаемый результат – user590028
@ user590028 не очевидно. Я сказал, что пытаюсь скопировать строку в связанный список. – psychoCoder