鱼C论坛

 找回密码
 立即注册
查看: 3867|回复: 11

[已解决]魔术师发牌问题

[复制链接]
发表于 2021-6-7 21:08:59 | 显示全部楼层 |阅读模式
20鱼币
本帖最后由 冰逸琉璃 于 2021-6-8 07:19 编辑

就是术师利用一副牌中的13张黑牌,预先将他们排好后叠放在一起,牌面朝下,魔术师将最上面的那张牌数为1,把他翻过来正好是黑桃A, 将黑桃A放到桌面上,第二次数1,2将第一张牌放在这些牌的下面,将第二张牌翻过来,正好是黑桃2, 也将它放在桌子上这样依次进行将13张牌全部翻出,准确无误。我是这样写的,感觉没有错误,但是运行出来不对,看了一天也没看出那错了,请教下大佬们
#include <stdio.h>
#include <stdlib.h>

#define MAX 13

typedef struct node
{
        int num;
        struct node* next;
}node;

node* initialization();//创建循环链表
void sort(node* p);//排序牌顺序

node* initialization()//创建链表
{
        node* head = NULL;
        node* s;//节点
        node* r = NULL;//指向最后一个节点

        for (int i = 0; i < MAX; i++)
        {
                s = (node*)malloc(sizeof(node));
                if (s == NULL)
                {
                        exit(1);
                }
                s->num = 0;
                if (head == NULL)
                {
                        head = s;
                        s->next = head;

                        r = head;
                }
                else
                {
                        r->next = s;
                        s->next = head;

                        r = s;
                }
        }
        return head;
}

void sort(node* p)//排序牌顺序
{
        node* head = p;
        int number = 2;
        int j;

        head->num = 1;

        while (1)
        {
                for (j = 0; j < number; j++)
                {
                        head = head->next;

                        if (head->num != 0)
                        {
                                head = head->next;
                                j--;
                        }
                }
                head->num = number++;

                if (number == MAX + 1)
                {
                        break;
                }
        }
}

int main(void)
{
        node* p;

        p = initialization();
        sort(p);

        for (int i = 0; i < MAX; i++)
        {
                printf("%d ", p->num);
                p = p->next;
        }

        return 0;
}
最佳答案
2021-6-7 21:09:00
类似这样的代码,没有意义,什么事情也不做
  1. #include <stdio.h>

  2. int main(void) {
  3.     1;
  4.     2;
  5.     3;
  6.     100;
  7.     ;
  8.     ;
  9.     int i = 100;
  10.     i + 1;
  11.     i;
  12.     printf("%d\n", i);
  13.     printf("hello world!\n");
  14.     return 0;
  15. }
复制代码
3.jpg
1.jpg
2.jpg

最佳答案

查看完整内容

类似这样的代码,没有意义,什么事情也不做
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-6-7 21:09:00 | 显示全部楼层    本楼为最佳答案   
类似这样的代码,没有意义,什么事情也不做
  1. #include <stdio.h>

  2. int main(void) {
  3.     1;
  4.     2;
  5.     3;
  6.     100;
  7.     ;
  8.     ;
  9.     int i = 100;
  10.     i + 1;
  11.     i;
  12.     printf("%d\n", i);
  13.     printf("hello world!\n");
  14.     return 0;
  15. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-6-7 21:11:18 | 显示全部楼层
代码在哪里
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-6-7 21:28:46 | 显示全部楼层
截图太糊了   
复制过来呀
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-6-8 07:19:03 | 显示全部楼层
万千只cnm 发表于 2021-6-7 21:28
截图太糊了   
复制过来呀

嗷嗷
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-6-8 10:40:01 | 显示全部楼层
你这个程序使用的是什么样的算法?
这个程序再我看来,使用递归的思想是不错的
首先把已经摆好的牌从上到下编号
要想摆好第1张,先要把第2张摆好,第2张要求先摆第3张
也就是先摆第13张然后是第12张。。。然后是第2张,然后是第1张
应该是倒着来的

完全就是取牌时候的反向操作
  1. #include <iostream>
  2. #include <list>

  3. std::ostream &operator<<(std::ostream &os, const std::list<size_t> &rhs) {
  4.     for(const auto &i: rhs) os << i << " ";
  5.     return os;
  6. }

  7. int main() {
  8.     std::list<size_t> list;
  9.     for(size_t i = 13; i > 0; --i) {
  10.         list.push_front(i);
  11.         for(size_t j = 1; j < i; ++j) {
  12.             size_t temp = list.back();
  13.             list.pop_back();
  14.             list.push_front(temp);
  15.         }
  16.     }
  17.     std::cout << list << std::endl;
  18.     return 0;
  19. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-6-8 16:21:27 | 显示全部楼层
人造人 发表于 2021-6-8 10:40
你这个程序使用的是什么样的算法?
这个程序再我看来,使用递归的思想是不错的
首先把已经摆好的牌从上到 ...

我这么想的,首先在位置1上放第一张牌,把number初始化为2(用来计下一次要走的步数),进入for循环 (j = 0; j < number ; j++) 后也就是走两步,if判断到这个位置已经放过牌的话j-1,然后再往前走一步,走完后让number加1,然后在这个位置上放牌        。可能我表达的不是太清楚
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-6-8 17:58:12 | 显示全部楼层
冰逸琉璃 发表于 2021-6-8 16:21
我这么想的,首先在位置1上放第一张牌,把number初始化为2(用来计下一次要走的步数),进入for循环 (j = 0 ...

看不懂你的想法,我认为你的方法无法实现这个题目要求
要想摆好第1张,先要把第2张摆好,第2张要求先摆第3张
也就是先摆第13张然后是第12张。。。然后是第2张,然后是第1张
我认为应该是倒着来的
我不知道怎样才能正着摆好所有的牌
你第1张牌应该摆在哪里?不知道吧?应该把第2张牌先摆好才能摆第1张牌吧?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-6-8 19:54:09 | 显示全部楼层
人造人 发表于 2021-6-8 17:58
看不懂你的想法,我认为你的方法无法实现这个题目要求
要想摆好第1张,先要把第2张摆好,第2张要求先摆 ...

改了这个地方以后好像就没问题了,之前应该是把Nhead->next写成Nhead=Nhead->next。
我现在就是还不理解这个Nhead->next是什么意思,和Nhead=Nhead->next有什么区别

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

  3. #define MAX 13

  4. typedef struct node
  5. {
  6.         int num;
  7.         struct node* next;
  8. }node;

  9. node* initialization();
  10. void sort(node* head);

  11. node* initialization()
  12. {
  13.         node* head = NULL;
  14.         node* s;
  15.         node* r = NULL;

  16.         for (int i = 0; i < MAX; i++)
  17.         {
  18.                 if (head == NULL)
  19.                 {
  20.                         head = (node*)malloc(sizeof(node));
  21.                         if (head == NULL)
  22.                         {
  23.                                 exit(1);
  24.                         }
  25.                         head->num = 0;

  26.                         head->next = head;

  27.                         r = head;
  28.                 }
  29.                 else
  30.                 {
  31.                         s = (node*)malloc(sizeof(node));
  32.                         if (s == NULL)
  33.                         {
  34.                                 exit(1);
  35.                         }
  36.                         s->num = 0;

  37.                         r->next = s;
  38.                         s->next = head;

  39.                         r = s;
  40.                 }
  41.         }
  42.         return head;
  43. }

  44. void sort(node* head)
  45. {
  46.         node* Nhead = head;
  47.         int number = 2;
  48.         int j;

  49.         Nhead->num = 1;

  50.         while (1)
  51.         {
  52.                 for (j = 0; j < number; j++)
  53.                 {
  54.                         Nhead = Nhead->next;

  55.                         if (Nhead->num != 0)
  56.                         {
  57.                                 Nhead->next;//改了这里
  58.                                 j--;
  59.                         }
  60.                 }

  61.                 if (Nhead->num == 0)
  62.                 {
  63.                         Nhead->num = number++;

  64.                         if (number == MAX + 1)
  65.                         {
  66.                                 break;
  67.                         }
  68.                 }
  69.         }
  70. }

  71. int main(void)
  72. {
  73.         node* head = NULL;

  74.         head = initialization();
  75.         sort(head);

  76.         for (int i = 0; i < MAX; i++)
  77.         {
  78.                 printf("%d ", head->num);
  79.                 head = head->next;
  80.         }

  81.         return 0;
  82. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-6-8 19:57:02 | 显示全部楼层
人造人 发表于 2021-6-8 17:58
看不懂你的想法,我认为你的方法无法实现这个题目要求
要想摆好第1张,先要把第2张摆好,第2张要求先摆 ...

依旧是从第一张开始排的
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-6-8 20:00:10 | 显示全部楼层
冰逸琉璃 发表于 2021-6-8 19:57
依旧是从第一张开始排的

Nhead->next;//改了这里
这条语句没有意义,这条语句什么也不做,去掉也完全没问题
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-6-8 20:11:43 | 显示全部楼层
人造人 发表于 2021-6-8 20:03
类似这样的代码,没有意义,什么事情也不做

哈哈哈,懂了 ,万分感谢,突然感觉好丢人,就这么点事还来问
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-28 02:08

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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