鱼C论坛

 找回密码
 立即注册
查看: 4130|回复: 1

[已解决]数据结构与算法课程的第18讲(线性表13),课后题

[复制链接]
发表于 2021-7-19 09:31:57 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

typedef struct node {
        int data;
        int password;
        struct node* next;        
} Node;

typedef Node* LinkList;

void InitList(LinkList *L);

void Sort(LinkList L);

int main(void)
{
        LinkList L;
        
        InitList(&L);
        
        Sort(L);
        
        return 0;
}

void InitList(LinkList *L)
{
        int i;
        LinkList temp, r;
        *L = (LinkList)malloc(sizeof(Node));
        (*L)->next = NULL;
        r = *L;
        
        for ( i=1; i<=41; i++)
        {
                temp = (LinkList)malloc(sizeof(Node));
                if (!temp)
                {
                        printf("内存分配失败!\n");
                        exit(0);
                }
                
                srand(time(0));
                temp->password = rand() %100 + 1;
                temp->data = i;
                temp->next = *L;
                r->next = temp;
                r = temp;
        }        
        
        temp = (*L)->next;
        
}

void Sort(LinkList L)
{
        int n = 41;
        int idx = 1;
        int i;
        int m;        // 存储 password
        LinkList temp, r;
        
        temp = (LinkList)malloc(sizeof(Node));
        if (!temp)
        {
                printf("内存分配失败!\n");
                exit(0);
        }
        
        r = (LinkList)malloc(sizeof(Node));
        if (!r)
        {
                printf("内存分配失败!\n");
                exit(0);
        }
        r = NULL;
        
        temp = L->next;
        free(L);
        
        while (temp != temp->next)
        {
                m = temp->password;
        
                m %= n;
                
                for ( i=1; i < m-1; i++)
                {
                        temp = temp->next;                
                }
                
                r = temp->next;
                printf("第 %d 位是:%d\n", idx++, r->data);
                
                temp = r->next;
                free(r);
        }
        
        
        
}


数据结构与算法课程的第18讲(线性表13),课后题,上边是我写的代码,好像是循环链表的指向出了问题,但是我才疏学浅看不出来,有没有帮忙运行一下看看的。
最佳答案
2021-7-22 15:26:43
void InitList(LinkList *L)
{
        int i;
        LinkList temp, r;
        *L = (LinkList)malloc(sizeof(Node));
        (*L)->next = NULL;
        r = *L;
        
        for ( i=1; i<=41; i++)
        {
                temp = (LinkList)malloc(sizeof(Node));
                if (!temp)
                {
                        printf("内存分配失败!\n");
                        exit(0);
                }
                
                srand(time(0));
                temp->password = rand() %100 + 1;
                temp->data = i;
                temp->next = *L;
                r->next = temp;
                r = temp;
        }        
        
        temp = (*L)->next;   //此处没有正确把链表环形化  正确操作为  temp->next = (*L)->next;
        
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-7-22 15:26:43 | 显示全部楼层    本楼为最佳答案   
void InitList(LinkList *L)
{
        int i;
        LinkList temp, r;
        *L = (LinkList)malloc(sizeof(Node));
        (*L)->next = NULL;
        r = *L;
        
        for ( i=1; i<=41; i++)
        {
                temp = (LinkList)malloc(sizeof(Node));
                if (!temp)
                {
                        printf("内存分配失败!\n");
                        exit(0);
                }
                
                srand(time(0));
                temp->password = rand() %100 + 1;
                temp->data = i;
                temp->next = *L;
                r->next = temp;
                r = temp;
        }        
        
        temp = (*L)->next;   //此处没有正确把链表环形化  正确操作为  temp->next = (*L)->next;
        
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-22 07:53

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表