中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++中約瑟夫環的示例分析

發布時間:2021-07-22 09:44:11 來源:億速云 閱讀:169 作者:小新 欄目:編程語言

這篇文章主要介紹了C++中約瑟夫環的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

約瑟夫環是一個數學的應用問題:已知n個人(以編號1,2,3...n分別表示)圍坐在一張圓桌周圍。從編號為k的人開始報數,數到m的那個人出列;他的下一個人又從1開始報數,數到m的那個人又出列;依此規律重復下去,直到圓桌周圍的人全部出列。

分析:有n個人,要想所有的人都退出去,只有每個人喊到m,才可以退完,所以可以算出,n*m為所有人總共報數的總次數。

代碼:

/* 
 *   約瑟夫出圈 
 */ 
#include <stdio.h> 
 
int main() 
{ 
  char peo[100] ; 
  char *p_peo = peo; 
  int i , n , skip , flag[100] = {0} , cnt; 
  int *p_flag = NULL; 
  printf("請輸入人數:"); 
  scanf("%d", &n); 
  printf("所有人如下:\n"); 
  for(p_peo , i = 0 ; p_peo < peo + n ; ++p_peo , ++i) 
  { 
    *p_peo = 'a' + i; 
    printf("%c ", *p_peo); 
  } 
  printf("\n"); 
 
  printf("請輸入報數值:"); 
  scanf("%d", &skip); 
 
  cnt = 0; 
  while(cnt <= n * skip) 
  { 
    for(p_peo = peo , p_flag = flag ; p_peo < peo + n ; ++p_peo , ++p_flag) 
    { 
      if(*p_flag) 
        continue; 
 
      cnt++; 
      if(!(cnt % skip)) 
      { 
        *p_flag = 1; 
        printf("%c ", *p_peo); 
      } 
    } 
  } 
  printf("\n"); 
  return 0; 
}

感謝你能夠認真閱讀完這篇文章,希望小編分享的“C++中約瑟夫環的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

c++
AI

邵阳县| 南阳市| 汉阴县| 郧西县| 通许县| 佛冈县| 常山县| 洛南县| 溧水县| 钟祥市| 汉沽区| 上饶县| 志丹县| 普陀区| 邵阳市| 广宁县| 治多县| 静宁县| 临洮县| 太原市| 金溪县| 淮北市| 类乌齐县| 白银市| 抚远县| 宝山区| 穆棱市| 海门市| 棋牌| 平利县| 福建省| 锦州市| 定西市| 静安区| 达孜县| 绥化市| 稻城县| 满洲里市| 班戈县| 嘉义县| 宜昌市|