数据结构实验||约瑟夫环

简介: 数据结构实验||约瑟夫环

一、实验目的

能够熟练掌握线性表的基本操作在顺序和链式两种存储结构上的实现,进一步理解线性表的逻辑结构和存储结构,提高使用理论知识指导解决实际问题的能力。


二、实验题目

约瑟夫问题的一种描述是:编号为1,2,,n的n个人按顺时针方向围坐一圈,每人持有一个密码(正整数)。开始时任选一个整数作为报数上限值m,从第一个人开始顺时针自1开始顺序报数,报到m时停止报数。报m的人出列,将他的密码作为新的m值,从他在顺时针方向上的下一个人开始重新从1报数,如此下去,直至所有的人全部出列为止。试设计一个程序,求出出列顺序。

利用单向循环链表作为存储结构模拟此过程,按照出列顺序打印出各人的编号。

例如,m的初值为20;n=7,7个人的密码依次是3,1,7,2,4,8,4,出列的顺序为6,1,4,7,2,3,5。


三、问题分析

1.数据分析

利用单向循环链表存储结构模拟报数过程,按照出列的顺序打印出个人的编号。

  1. 正确的输入的形式和输入值的范围
  2. 输出格式
  3. 程序所能达到的功能
  4. 进行数据测试
2.运算分析

程序命令应包括:构造单循环链表,输入数据创建约瑟夫循环链表显示表中数据内容,元素依次随机输出。

用主函数在其中放这些所需功能的函数。

3.主要算法分析

形成约瑟环初始化,通过建立指针,用for循环进行遍历

void joseph_init(int n)  /*约瑟夫环初始化*/
{
  int i;
 
  node *p = mk_node(1);
  head = p;
  tail = p;
 
  for (i = 2; i <= n; i++)
  {
    p = mk_node(i);
    tail->next = p;
    tail = p;
  }
  tail->next = head;
  traverse();
}

建立循环链表,逢m便将其剔除。报m的人出列,将他的密码作为新的m值,从他在顺时针方向上的下一个人开始重新从1报数。

int joseph(int n)  /*剔除算法*/
{
  int total = 0;
  node *p ;
  node *pre;
  int surv;
  
  joseph_init(n);
  p = head;
  pre = tail;
 
  while (p->next != p)
  {
    total++;
 
    if (total == 3)
    {
      pre->next = p->next;
      p->next = NULL;
      printf("出列的序号是:%d\n", p->item);
      free_node(p);
      p = pre->next;
      total = 0;
 
      continue;
    }
 
    p = p->next;
    pre = pre->next;
  }
  surv = p->item;
  free_node(p);
 
  return surv;
}
4.测试数据分析

包括正确的输入及其输出结果和含有错误的输入及其输出结果

输入:123456789

输出:369485271

四、源程序

#include <stdio.h>
#include <stdlib.h>
 
typedef struct node  /*头指针型约瑟夫环*/
{
    int item;
    struct node *next;
}node;
 
node *head = NULL;  /*头空*/
node *tail = NULL;  /*尾空*/
node *mk_node(int item) //分配地址空间,创建节点
{
  node *p = (node *)malloc(sizeof(node));
  if (p == NULL)
  {
    printf("malloc failed\n");
    exit(1);
  }
 
  p->item = item;
  p->next = NULL;
 
  return p;
}
 
void free_node(node *p) //释放节点
{
  free(p);
}
 
void traverse() //遍历
{
  node *p = head;
 
  while (p->next != head)
  {
    printf("%d ", p->item);
    p = p->next;
  }
  printf("将数据都输入约瑟夫循环中:%d ", p->item);
  printf("\n");
}
 
void joseph_init(int n)  /*约瑟夫环初始化*/
{
  int i;
 
  node *p = mk_node(1);
  head = p;
  tail = p;
 
  for (i = 2; i <= n; i++)
  {
    p = mk_node(i);
 
    tail->next = p;
    tail = p;
  }
 
  tail->next = head;
  traverse();
}
 
int joseph(int n)  /*剔除算法*/
{
  int total = 0;
  node *p ;
  node *pre;
  int surv;
  
  joseph_init(n);
  p = head;
  pre = tail;
 
  while (p->next != p)
  {
    total++;
 
    if (total == 3)
    {
      pre->next = p->next;
      p->next = NULL;
      printf("出列的序号是:%d\n", p->item);
      free_node(p);
      p = pre->next;
      total = 0;
 
      continue;
    }
 
    p = p->next;
    pre = pre->next;
  }
  surv = p->item;
  free_node(p);
 
  return surv;
}
 
int main()
{int n;
printf(“input your numbers:\n”);
Scanf(“%d”,%n);
  printf("the last is %d\n",  joseph(n));
 
  return 0;
}

相关文章
|
1月前
|
存储 算法 编译器
数据结构实验之矩阵的运算器(二维数组)
本实验旨在通过团队合作,掌握数组和矩阵相关运算的代码实现,包括矩阵的加减、数乘、转置、乘法、n次方及行列式的计算。实验过程中,成员们需分工协作,解决编程难题,最终实现一个功能完备的矩阵计算器。通过本实验,不仅锻炼了编程能力,还加深了对数学概念的理解,同时培养了团队合作精神。
66 4
|
1月前
数据结构实验之串模式匹配问题
本实验旨在掌握串模式匹配技术,通过创建文本文件、实现单词计数与定位功能,最终构建一个包含文件建立、单词统计与定位、程序退出等选项的主菜单,以增强对字符串处理的理解与应用能力。
59 4
|
1月前
|
算法
数据结构实验之最长公共子序列
本实验旨在通过编程实践帮助学生理解串的基本概念及求解最长公共子序列的算法。实验内容包括使用动态规划方法设计并实现算法,以找出给定两序列的最大公共子序列。示例代码展示了如何通过构建状态矩阵和回溯路径来找到解决方案。实验总结指出,`memset()`函数用于内存初始化,且对于特定输入,程序能正确输出最长公共子序列之一。
58 4
|
1月前
|
算法
数据结构实验之操作系统打印机管理器问题
本实验旨在通过实现操作系统中的打印机管理器问题,掌握队列的基本操作如入队、出队等,利用队列的先进先出特性解决先申请先打印的问题。实验包括队列的初始化、入队、出队、打印队列内容等功能,并通过菜单式界面进行交互。实验结果显示基本功能可正常执行,但在连续操作时存在执行失败的情况,需进一步优化。
48 4
|
1月前
|
存储 算法 Perl
数据结构实验之链表
本实验旨在掌握线性表中元素的前驱、后续概念及链表的建立、插入、删除等算法,并分析时间复杂度,理解链表特点。实验内容包括循环链表应用(约瑟夫回环问题)、删除单链表中重复节点及双向循环链表的设计与实现。通过编程实践,加深对链表数据结构的理解和应用能力。
62 4
|
1月前
|
机器学习/深度学习 存储 算法
数据结构实验之二叉树实验基础
本实验旨在掌握二叉树的基本特性和遍历算法,包括先序、中序、后序的递归与非递归遍历方法。通过编程实践,加深对二叉树结构的理解,学习如何计算二叉树的深度、叶子节点数等属性。实验内容涉及创建二叉树、实现各种遍历算法及求解特定节点数量。
89 4
|
1月前
|
存储 人工智能 算法
数据结构实验之C 语言的函数数组指针结构体知识
本实验旨在复习C语言中的函数、数组、指针、结构体与共用体等核心概念,并通过具体编程任务加深理解。任务包括输出100以内所有素数、逆序排列一维数组、查找二维数组中的鞍点、利用指针输出二维数组元素,以及使用结构体和共用体处理教师与学生信息。每个任务不仅强化了基本语法的应用,还涉及到了算法逻辑的设计与优化。实验结果显示,学生能够有效掌握并运用这些知识完成指定任务。
60 4
|
6月前
|
存储 算法 数据安全/隐私保护
【Python学习篇】Python实验小练习——高级数据结构(五)
【Python学习篇】Python实验小练习——高级数据结构(五)
79 1
|
2月前
|
算法 Java
数据结构与算法学习六:单向环形链表应用实例的约瑟夫环问题
这篇文章通过单向环形链表的应用实例,详细讲解了约瑟夫环问题的解决方案,并提供了Java代码实现。
31 0
|
2月前
|
算法
计科一二班算法数据结构实验9答案
计科一二班算法数据结构实验9答案
21 0