C:向后打印链表

时间:2011-08-23 23:20:40

标签: c linked-list

尝试向后打印此列表

用户输入10个字符,程序按原始顺序打印10个字符,然后按相反顺序打印。

感谢你们,我想出了为什么它不会按正常顺序打印的问题,现在我在以相反的顺序打印时遇到了一些麻烦..

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define strsize 30

typedef struct member
{
    int number;
    char fname[strsize];
    struct member *next;
} RECORD;

RECORD* insert (RECORD *it);
RECORD* print(RECORD *it, int j);

int main (void)
{
    int i;
    double result;
    RECORD *head, *p;
    head=NULL;
    result=10;

    for (i=1; i<=result; i++)
        head=insert (head);  
    print (head, result);

    return 0;

}

RECORD* insert (RECORD *it)
{

    RECORD *cur, *q; 
    int num;
    char junk;
    char first[strsize];
    printf("Enter a character:");
    scanf("%s", &first);

    cur=(RECORD *) malloc(sizeof(RECORD));

    strcpy(cur->fname, first);
    cur->next=NULL; 

    if (it==NULL)
        it=cur;
    else
    {
        q=it;
        while (q->next!=NULL)
            q=q->next;
        q->next=cur;
    }

    return (it);
}

RECORD* print(RECORD *it, int j)
{
    RECORD *cur;
    cur=it;
    int i;
    for(i=1;i<=j;i++)
    {
        printf("%s \n", cur->fname);
        cur=cur->next;

        //my solution for printing it backwards..

        void print(node *it)
        {
            if(it!=NULL)
            {
                print(it->next);
                printf("%s-->",it->number);
            }
        }

        return;
    }
}

1 个答案:

答案 0 :(得分:2)

您有几个名称为print

的“事物”
  • 原型:RECORD* print(RECORD *it, int j);
  • 来电mainprint (head, result);
  • 功能定义:RECORD* print(RECORD *it, int j) {
  • 嵌套函数定义:void print(node *it) {

前三个是连贯的,但最后一个是完全错误的。

另外
标准C不允许嵌套函数 类型node未定义 你仍然需要处理你的缩进:)