理解 约瑟夫环

2024-09-02 11:58
文章标签 理解 约瑟夫

本文主要是介绍理解 约瑟夫环,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

总结了个小经验,有时候光靠看是看不出什么端倪来的,还必须得动下笔,比划比划也许就那么简单


#include <stdio.h>

#include <stdlib.h>

typedef struct Node

{

 int data;

 struct Node *next;

}Node;

 

Node *CreatList(int n)    //创建一个含n个人的循环链表

{

int i;

Node *head,*p,*q;

head=(Node*)malloc(sizeof(Node));

    head->data=1;

p=head;

for(i=2;i<=n;i++)    //利用尾插法构建长度为n的链表

{

q=(Node*)malloc(sizeof(Node));

p->next=q;

q->data=i;

p=p->next;

}

p->next=head;       //构建循环链表

return(head);

}

 

 

void Joseph(Node *head,int n,int m)  //n:总人数     m:出列的数字

{

int i,j;

Node *p,*q;

    p=head;

for (j=1;j<=n;j++)                                                                                                                      

   {

        for(i=1;i<m;i++)

p=p->next;        //找到应出列的人

          printf("% d",p->data);

          p->data=p->next->data;

          q=p->next;

          p->next=p->next->next;

          free(q);   //释放指针q所指变量的存储空间

   }

}

void main()

{

int n,m;

Node *head;

printf("请输入总人数n:   ");

scanf("%d",&n);

printf("\n请输入出列者报的数m:  ");

scanf("%d",&m);

printf("\n");

head=CreatList(n);    //调用创建列表函数

Joseph(head,n,m);   //调用约瑟夫环函数

printf("\n");

printf("\n");

 

}

自己优化的代码

#include<stdio.h>

#include<stdlib.h>

typedef struct node

{

int data;

node *next;

};

int m,n;

node *head;

void creat()

{

int i;

node *p,*q;

head=(node*)malloc(sizeof(node));

head->data=1;

p=head;

for(i=2;i<=n;i++)

{

q=(node*)malloc(sizeof(node));

p->next=q;

q->data=i;

p=p->next;

}

p->next=head;

}

void jose()

{

int i,j;

node *p,*q;

p=head;

for(j=1;j<=n;j++)

{

for(i=1;i<m;i++)

 p=p->next;           //??????°?p->next??????p???? 

 printf("%d ",p->data);

 p->data=p->next->data;

 q=p->next;      //????q=p;

 p->next=p->next->next;

 free(q);

}

}

int main()

{

while(scanf("%d%d",&n,&m)!=EOF)

{

    creat();

jose();

printf("\n");

}

}

这篇关于理解 约瑟夫环的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1129886

相关文章

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

深入理解go中interface机制

《深入理解go中interface机制》本文主要介绍了深入理解go中interface机制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前言interface使用类型判断总结前言go的interface是一组method的集合,不

Java Spring的依赖注入理解及@Autowired用法示例详解

《JavaSpring的依赖注入理解及@Autowired用法示例详解》文章介绍了Spring依赖注入(DI)的概念、三种实现方式(构造器、Setter、字段注入),区分了@Autowired(注入... 目录一、什么是依赖注入(DI)?1. 定义2. 举个例子二、依赖注入的几种方式1. 构造器注入(Con

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

spring IOC的理解之原理和实现过程

《springIOC的理解之原理和实现过程》:本文主要介绍springIOC的理解之原理和实现过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、IoC 核心概念二、核心原理1. 容器架构2. 核心组件3. 工作流程三、关键实现机制1. Bean生命周期2.

深入理解Apache Kafka(分布式流处理平台)

《深入理解ApacheKafka(分布式流处理平台)》ApacheKafka作为现代分布式系统中的核心中间件,为构建高吞吐量、低延迟的数据管道提供了强大支持,本文将深入探讨Kafka的核心概念、架构... 目录引言一、Apache Kafka概述1.1 什么是Kafka?1.2 Kafka的核心概念二、Ka

深入理解Apache Airflow 调度器(最新推荐)

《深入理解ApacheAirflow调度器(最新推荐)》ApacheAirflow调度器是数据管道管理系统的关键组件,负责编排dag中任务的执行,通过理解调度器的角色和工作方式,正确配置调度器,并... 目录什么是Airflow 调度器?Airflow 调度器工作机制配置Airflow调度器调优及优化建议最

一文带你理解Python中import机制与importlib的妙用

《一文带你理解Python中import机制与importlib的妙用》在Python编程的世界里,import语句是开发者最常用的工具之一,它就像一把钥匙,打开了通往各种功能和库的大门,下面就跟随小... 目录一、python import机制概述1.1 import语句的基本用法1.2 模块缓存机制1.

深入理解C语言的void*

《深入理解C语言的void*》本文主要介绍了C语言的void*,包括它的任意性、编译器对void*的类型检查以及需要显式类型转换的规则,具有一定的参考价值,感兴趣的可以了解一下... 目录一、void* 的类型任意性二、编译器对 void* 的类型检查三、需要显式类型转换占用的字节四、总结一、void* 的