• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > 利用简洁的C语言代码解决跳台阶问题与约瑟夫环问题

利用简洁的C语言代码解决跳台阶问题与约瑟夫环问题

作者:Zhang_H 字体:[增加 减小] 来源:互联网 时间:2017-05-28

Zhang_H 通过本文主要向大家介绍了约瑟夫环问题,约瑟夫环问题c代码,约瑟夫环问题实验报告,java约瑟夫环问题,约瑟夫环问题c等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

跳台阶问题

题目:

一个台阶总共有 n 级,如果一次可以跳 1 级,也可以跳 2 级。

求总共有多少总跳法,并分析算法的时间复杂度。

分析:

也是比较基础的题目,通过递归可以方便的求解

代码实现如下(GCC编译通过):

#include "stdio.h"
#include "stdlib.h"
 
int function(int n);
 
int main(void)
{
  int tmp;
   
  tmp = function(5);
  printf("%3d\n",tmp);
 
  return 0;
}
 
int function(int n)
{
  if(n == 1)
    return 1;
  else if(n == 2)
    return 2;
  else  
    return function(n-1) + function(n-2);
}

</div>


约瑟夫环问题
题目:

n个数字(0,1,…,n-1)形成一个圆圈,从数字0开始,每次从这个圆圈中删除第m个数字(第一个为当前数字本身,第二个为当前数字的下一个数字)。当一个数字删除后,从被删除数字的下一个继续删除第m个数字。求处在这个圆圈中剩下的最后一个数字。

(其实说了这么多就是约瑟夫环问题)

分析:

以前学习链表的时候也见过约瑟夫环问题,当时是拿循环链表模拟整个过程来解决的,今天在网上看到一种分析。记录下来:

    题目要求最后剩下的一个数(用last表示),也就是这个数是第几个,在(0,1,…,n-1)的位置是多少。明确了题目中的信息,所以我们要对这个数进行归纳。假设知道这个数在剩下的k个数中的位置,怎么来求得它在剩余K+1个数中的位置,这样一步一步推导出它在有n个数中的位置,即为所求。为什么能这样归纳,因为这个最后剩下的数在所有删除过程中有幸存活下来,只不过每次删除了一个数,它的位置就变了,知道最后,它的位置为0(只剩一个数了)。

现在来分析删除第一个数后,last这个数的位置已之前有什么样的关系。在这n个数字中,第一个被删除的数字是(m-1)%n,为简单起见记为k。那么删除k之后的剩下n-1的数字为0,1,…,k-1,k+1,…,n-1,并且下一个开始计数的数字是k+1。相当于在剩下的序列中,k+1排到最前面,从而形成序列k+1,…,n-1,0,…k-1。

k+1    ->    0
k+2    ->    1
…
n-1    ->    n-k-2
0       ->    n-k-1
…
k-1   ->   n-2

现在我们知道了有n-1个数时last的位置,记为f(n-1,m),那么如何来求得f(n,m)关于f(n-1,m)之间的关系?用X,Y来表示,如下:

Y              X

k+1    ->    0
k+2    ->    1
…
n-1    ->    n-k-2
0       ->     n-k-1
…
k-1    ->    n-2

y=( x+k+1) %n

k = (m-1)%n

所以y=(x+m)%n,最终关系如下:

                0                              n=1
f(n,m)={
                [f(n-1,m)+m]%n     n>1

根据关系可以很方便的得到代码

代码实现如下:

int LastRemaining(int n, int m)
{
  if(n < 1 || m < 1)
    return -1;
 
  int last = 0;
  for (int i = 2; i <= n; i ++) 
    last = (last + m) % i;
 
  return last;
}
</div>

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C++ 中约瑟夫环替换计数器m(数组解决)
  • 利用简洁的C语言代码解决跳台阶问题与约瑟夫环问题
  • 详解约瑟夫环问题及其相关的C语言算法实现
  • C++循环链表之约瑟夫环的实现方法
  • 约瑟夫环问题(数组法)c语言实现
  • HDOJ 1443 约瑟夫环的最新应用分析详解
  • 深入理解约瑟夫环的数学优化方法

相关文章

  • 2017-05-28C#中委托的基本用法总结
  • 2017-05-28深入C/C++浮点数在内存中的存储方式详解
  • 2017-05-28浅析c与c++中struct的区别
  • 2017-05-28__stdcall 和 __cdecl 的区别浅析
  • 2022-04-30C语言指针作为函数返回值
  • 2017-05-28C++调用Python基础功能实例详解
  • 2017-05-28c++递归实现n皇后问题代码(八皇后问题)
  • 2017-05-28详解C++中的vector容器及用迭代器访问vector的方法
  • 2017-05-28C++实现图的邻接矩阵存储和广度、深度优先遍历实例分析
  • 2017-05-28C++指针数组、数组指针、数组名及二维数组技巧汇总

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 大数(高精度数)模板(分享)
    • 怎么锁定鼠标的示例代码分享
    • C++ 冒泡排序数据结构、算法及改进算法
    • 有关C++继承与友元、继承与类型转换详解
    • VC下通过系统快照实现进程管理的方法
    • VC小技巧汇总之窗口技巧
    • 递归法求最大公约数和最小公倍数的实现代码
    • 浅析c#中如何在form的webbrowser控件中获得鼠标坐标
    • C++选择排序算法实例
    • C语言双向链表实现根据使用频率安排元素位置的功能实例代码

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有