fujx23 2022-01-03 09:45 采纳率: 91.7%
浏览 21
已结题

无法获得预期的输入结果,预期输入8时获得7,但结果仍然为8,如何解决?

问题:题目:有n个人围成一圈,顺序排号,从第一个开始报数(从1到3报数),凡报到3的人退出圈子,问最后最后留下的是原来第几号的那位.

问题相关代码,请勿粘贴截图
#include <stdio.h>
int main()
{    int i,j,k=0,l=0,m=0,A[50];
    printf("How many ?\n");
    scanf("%d",&i); 
    for(j=0;j<i;j++) 
    *(A+j)=j+1;
    while(m<i-1)
    {if(A[l]!=0) k++;
     if(k%3==0)
        {A[l]=0;
         k=0;
         m++;}
        l++;
     if(l==i) l=0;    
    }
    while(A[l]==0) l++;
    printf("%d",A[l]);
    return 0;
}

运行结果及报错内容
我的解答思路和尝试过的方法
我想要达到的结果
  • 写回答

2条回答 默认 最新

  • fuill 2022-01-03 10:21
    关注

    试试这个

    #include<stdio.h>
    #include<malloc.h>
    struct node
    
    {
        int num;
    
        struct node *next;
    
    };
    
    struct node *head;
    
    struct node *last;
    
    void cre_list()
    
    {
        head = (struct node *)malloc(sizeof(struct node));
    
        last = head;
    
        head->next = head;
    
    }
    
    void display_node()
    
    {
        struct node *ptr = head->next;
    
        while(ptr != head)
    
        {
            // printf("%d\t",ptr->num);
    
            ptr = ptr->next;
    
        }
    
        //printf("\n");
    
    }
    
    void add_node(int num)
    
    {
        struct node *ptr = (struct node *)malloc(sizeof(struct node));
    
        ptr->num = num;
    
        ptr->next = head;
    
        last->next = ptr;
    
        last = ptr;
    
    }
    
    void rev_node()
    
    {
        struct node *ptr = head;
    
        last->next = head->next;
    
        head = head->next;
    
        free(ptr);
    
    }
    
    void tiren_node()
    
    {
        struct node *ptr = head;
    
        struct node *str = ptr->next;
    
        struct node *qtr = str->next;
    
        while(ptr->next != ptr)
    
        {
            str = ptr->next;
    
            qtr = str->next;
    
            str->next = qtr->next;
    
            ptr = str->next;
    
        }
    
        printf("%d",ptr->num);
    
    }
    
    int main()
    
    {
        int i = 0;
    
        cre_list();
    
        int n;
    
        //printf("please input n:\n");
        printf("How many ?\n");
    
        scanf("%d",&n);
    
        // printf("%d\n",n);
    
        for(i = 1; i <= n; i++)
    
        {
            add_node(i);
    
        }
    
        display_node();
    
        rev_node();
    
        tiren_node();
    
        return 0;
    
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月14日
  • 已采纳回答 3月6日
  • 创建了问题 1月3日

悬赏问题

  • ¥15 win10权限管理,限制普通用户使用删除功能
  • ¥15 minnio内存占用过大,内存没被回收(Windows环境)
  • ¥65 抖音咸鱼付款链接转码支付宝
  • ¥15 ubuntu22.04上安装ursim-3.15.8.106339遇到的问题
  • ¥15 求螺旋焊缝的图像处理
  • ¥15 blast算法(相关搜索:数据库)
  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?
  • ¥15 网络通信安全解决方案
  • ¥50 yalmip+Gurobi
  • ¥20 win10修改放大文本以及缩放与布局后蓝屏无法正常进入桌面