約瑟夫問題 C語言鏈表實現

来源:https://www.cnblogs.com/tao-zhu-forever/archive/2018/04/21/8902421.html
-Advertisement-
Play Games

1.首先,我們先來瞭解一下什麼是約瑟夫環問題: 講一個比較有意思的故事:約瑟夫是猶太軍隊的一個將軍,在反抗羅馬的起義中,他所率領的軍隊被擊潰,只剩下殘餘的部隊40餘人,他們都是寧死不屈的人,所以不願投降做叛徒。一群人表決說要死,所以用一種策略來先後殺死所有人。 於是約瑟夫建議:每次由其他兩人一起殺死 ...


1.首先,我們先來瞭解一下什麼是約瑟夫環問題:

講一個比較有意思的故事:約瑟夫是猶太軍隊的一個將軍,在反抗羅馬的起義中,他所率領的軍隊被擊潰,只剩下殘餘的部隊40餘人,他們都是寧死不屈的人,所以不願投降做叛徒。一群人表決說要死,所以用一種策略來先後殺死所有人。 
於是約瑟夫建議:每次由其他兩人一起殺死一個人,而被殺的人的先後順序是由抽簽決定的,約瑟夫有預謀地抽到了最後一簽,在殺了除了他和剩餘那個人之外的最後一人,他勸服了另外一個沒死的人投降了羅馬。

 

通俗來說就是:

按照如下規則去殺人:

  • 所有人圍成一圈
  • 順時針報數,每次報到3的人將被殺掉
  • 被殺掉的人將從房間內被移走
  • 然後從被殺掉的下一個人重新報數,繼續報3,再清除,直到剩餘一人

那麼程式實現為:

  鏈表的定義: 定義為編號即可 所以data項為int

  

typedef struct NODE{
    struct NODE *next;
    int data;
}Node,*Linklist;

 

由於是迴圈,直到最後一個人, 所有可以使用特殊的鏈表: 迴圈鏈表。 當鏈表中只剩下一個元素後,便認為完事了。 即 L->next = L;

#include <stdio.h>
#include <stdlib.h>
#include "Linklist.h"

void Print_Linklist(Linklist L)
{
    Linklist head = L;
    printf("List: ");
    while(L->next != head)
    {
        printf("%d ",L->data);
        L = L->next;
    }
    printf("%d ",L->data);
    printf("\n");
}

int main()
{
    int i;
    Linklist L;
    Linklist head;
    Linklist Out;
    L = (Node*)malloc(sizeof(Node));
    head = L;
    L->data = 1;
    L->next = head;
    for(i=2;i<=41;i++)
    {
        L->next=(Node*)malloc(sizeof(Node));
        L->next->data = i;
        L->next->next = head;
        L = L->next;
    }
    Print_Linklist(head);
    L = head;
    while(L != L->next)
    {
         for(i=1;i<2;i++)
         {
             L = L->next;
         }
         Out = L->next;
         printf("%2d號 ----> 自殺!\n",Out->data);
         L ->next = Out->next;
         L = L->next;
         free(Out);
    }
    printf("幸存者是:%d",L->data);
    return 0;
}


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 徐亮偉, 江湖人稱標桿徐。多年互聯網運維工作經驗,曾負責過大規模集群架構自動化運維管理工作。擅長Web集群架構與自動化運維,曾負責國內某大型電商運維工作。 個人博客" "徐亮偉架構師之路" "累計受益數萬人。 筆者Q:552408925、572891887 架構師群:471443208 雲計算基本概 ...
  • 001
    2018.4.21溫故而知新,可以為師矣。 在JZ2440的板子上,有GPIO控制器,這裡我打算用GPF4作為輸出。 那麼怎麼讓GPF4輸出1或者0?可以通過:①配置為輸出引腳(配置GPFCON) ②設置狀態(配置GPFDAT) 在JZ2440的板子上有CPU,裡面有R0,R1......R15寄存 ...
  • 上幾節已經大致跟大家說了在Linux端文件目錄操作的一些命令 這篇隨筆,我們繼續來學習對文件目錄的操作命令 對文件或目錄進行查找的命令 find 指定目錄下查找文件 find命令可以用來在特定目錄下查找文件,預設是需要加上查找的路徑的,如果不加路徑,則find命令會在當前目錄查找子目錄和文件 然後把 ...
  • Python基礎第二章 二進位 字元編碼 基本數據類型 數字 基本數據類型 字元串 基本數據類型 列表 基本數據類型 元組 可變、不可變數據類型和hash 基本數據類型 字典 基本數據類型 集合 二進位 二進位是計算技術中採用的一種進位。二進位數由0和1兩個數位組成,它的基數為2,進位規則是“逢二進 ...
  • 這是CentOS內核的初始設置頁面,下麵給出中文解釋及操作方法。 ...
  • CentOS 7 預設是沒有圖形化界面的,但我們很多人在習慣了 Windows 的圖形化界面之後,總是希望有一個圖形化界面從而方便我們使用,這裡介紹一下 CentOS7安裝圖形化桌面系統的方法。 ...
  • 因centos 6.x 預設openssh掃描存在漏洞,基於安全考慮,需要將openssh_5.3p1升級為最新版1、下載安裝包https://cloudflare.cdn.openbsd.org/pub/OpenBSD/OpenSSH/portable/[root@zabbix-serv ~]# ... ...
  • 安裝流程: 1.準備安裝文件: 方法1: 使用內置火狐瀏覽器訪問下載最新格式為tar.gz的壓縮包 網址:https://www.jetbrains.com/pycharm/download/previous.html 方法2: 命令行模式中輸入命令: ps:weget命令預設下載到當前文件夾下 2 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...