zoukankan      html  css  js  c++  java
  • 数据结构-约瑟夫环

    #include <stdio.h>
    #include <malloc.h>
    typedef struct node{
        int key;
        int num;
        struct node * next;
    }node, * plist;
    
    //顺序创建
    int init(plist * L, int all_num){
        plist p;
        int i;
        *L = p = (plist)malloc(sizeof(node));
        p->num = 1;
        p->next = NULL;
        for(i = 2; i <= all_num; i++){
            p->next = (plist)malloc(sizeof(node));
            p = p->next;
            p->num = i;
            p->next = NULL;
        }
        p->next = *L;
        return 1;
    }
    
    //显示
    void Print(plist L, int all_num) {
        plist p;
        int i = 0;
        p = L;
        while (p && i!=all_num) {
            printf("%d    ", p->num);
            p = p->next;
            i++;
        }
        printf("
    ");
    }
    
    //输入key
    void Input(plist L, int all_num) {
        plist p;
        int i = 0;
        p = L;
        while (p && i!=all_num) {
            printf("%d的key是多少?", p->num);
            scanf("%d", &p->key);
            p = p->next;
            i++;
        }
    }
    
    //删除节点
    void delete(plist * L, plist p){
        plist swap = *L;
        while(swap){
            if(swap->next == p){
                swap->next = p->next;
                if(*L == p)
                    *L = swap->next;
                free(p);
                break;
            }
            swap = swap->next;
        }
    }
    
    int main(void) {
        plist L, p, swap;
        int all_num, kill_num, j, count;
    
        puts("多少人围一圈?");
        scanf("%d", &all_num);
        puts("初始key?");
        scanf("%d", &kill_num);
    
        if(!init(&L, all_num))
            puts("初始化失败");
    
        puts("初始化成功,编号已给!");
        Print(L, all_num);
    
        puts("请输入密码");
        Input(L, all_num);
    
        puts("开始!");
        count = 0;
        j = 1;//依次报数
        swap = p = L;
        while(count != all_num){
                if(kill_num == j){
                    Print(L, all_num-count);
                    printf("从%d开始数 key为%d
    ", swap->num, kill_num);
                    printf("%d出列
    
    ", p->num);
                    kill_num = p->key;
                    swap = p->next;
                    delete(&L, p);
                    p = swap;
                    j = 1;
                    count++;
                    continue;
                }
            j++;
            p = p->next;
        }
        if(count == all_num)
            printf("ok
    ");
    //    L = p = swap = NULL;
        return 0;
    }

     

  • 相关阅读:
    Stm32CubeMX5 配置 STM32的串口DMA接受方式 --- 基于 stm32f051k8u6
    Stm32 控制1.44寸液晶显示图片 基于stm32f051k8u6
    makefile自动编译
    Stm32CubeMX5 创建LED控制工程
    ARM 汇编与C之间 的调用
    shell 脚本文件类型.sh ,变量
    bzoj3589 动态树 求链并 容斥
    bzoj2287【POJ Challenge】消失之物 缺一01背包
    bzoj2916: [Poi1997]Monochromatic Triangles 思路
    [NOI2010]超级钢琴 主席树
  • 原文地址:https://www.cnblogs.com/startnow/p/5052604.html
Copyright © 2011-2022 走看看