一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - 利用簡潔的C語言代碼解決跳臺階問題與約瑟夫環問題

利用簡潔的C語言代碼解決跳臺階問題與約瑟夫環問題

2021-03-24 15:53Zhang_H C/C++

這篇文章主要介紹了利用簡潔的C語言代碼解決跳臺階問題與約瑟夫環問題的方法,跳臺階問題與約瑟夫環問題是常見的基礎算法題目,需要的朋友可以參考下

跳臺階問題

題目:

一個臺階總共有 n 級,如果一次可以跳 1 級,也可以跳 2 級。

求總共有多少總跳法,并分析算法的時間復雜度。

分析:

也是比較基礎的題目,通過遞歸可以方便的求解

代碼實現如下(GCC編譯通過):

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#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);
}


約瑟夫環問題
題目:

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

根據關系可以很方便的得到代碼

代碼實現如下:

?
1
2
3
4
5
6
7
8
9
10
11
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;
}

延伸 · 閱讀

精彩推薦
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
  • C/C++C/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
主站蜘蛛池模板: kisssis无减删全集在线观看 | bbbbbbaaaaaa毛片| 久久成人伊人欧洲精品AV | 日本不卡1卡2卡三卡网站二百 | 99爱视频| kkkk4444在线看片免费 | 7777奇米四色 | 欧美乱理伦另类视频 | 羞羞私人影院可以直接免费观影吗 | 青草国内精品视频在线观看 | 三上悠亚精品专区久久 | 亚洲aⅴ天堂 | 边摸边吃奶边做爽视频免费 | 天堂va在线高清一区 | 涩涩屋视频在线观看 | 日本在线你懂的 | 不卡日本| 青青热久免费精品视频精品 | 2022最新a精品视频在线观看 | 欧美日韩一区二区综合在线视频 | 日韩国产欧美精品综合二区 | 日本h片在线 | 我的绝色岳每雯雯 | 四虎影视在线观看2413 | 草久久网| 午夜想想爱午夜剧场 | 国产亚洲精品日韩香蕉网 | 变态女王麻麻小说在线阅读 | 二次元美女扒开内裤露尿口 | 秋霞午夜视频在线观看 | 精品久久亚洲 | 国产精品国产高清国产专区 | 男人躁女人过程 | 午夜一个人在线观看完整版 | 四虎影视在线看免费 720p | 无码中文字幕热热久久 | 日本孕妇大胆孕交 | 精品一区二区三区免费站 | julia ann黑人巨大 | 亚洲色导航 | 男人的天堂在线观看视频不卡 |