魔术师发牌问题(数据结构)

笔记

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

#define CardNumber 13

typedef struct node
{
    int data;
    struct node *next;
}sqlist,*linklist;

linklist CreateLinkList()
{
    linklist head = NULL;
    linklist s,r;
    int i;

    r = head;

    for(i=1; i<=CardNumber; i++)
    {
        s = (linklist)malloc(sizeof(sqlist));
        s->data = 0;

        if(head == NULL)
        {
            head = s;
        }
        else
        {
            r->next = s;
        }
        r = s;
        r->next = head;
    }
    return head;
}

//发牌顺序计算
void Magician(linklist head)
{
    linklist pa;
    int j;
    int Countnumber = 2;

    pa = head;
    pa->data = 1;//阿权,这条语句一执行,pa->next->data也会被赋值为1

    while(1)
    {
        for(j=0; j<Countnumber; j++)
        {
            pa = pa->next;
            if(pa->data != 0)
            {
                pa->next;
                j--;
            }
        }


        if(pa->data == 0)
        {
            pa->data = Countnumber;
            Countnumber++;

            if(Countnumber == 14)
            {
                break;
            }
        }

    }
}

//销毁工作
void DestoryList(linklist *list)
{
    linklist ptr = *list;
    linklist buff[CardNumber];
    int i=0;

    while(i < CardNumber)
    {
        buff[i++] = ptr;
        ptr = ptr->next;
    }

    for(i=0; i<CardNumber; ++i)
    {
        free(buff[i]);
    }

    *list = 0;
}



int main()
{
    linklist p;
    int i;

    p = CreateLinkList();
    Magician(p);

    printf("按如下顺序排列:\n");
    for(i=0; i<CardNumber; ++i)
    {
        printf("黑桃%d ",p->data);
        p = p->next;
    }

    DestoryList(&p);

    return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值