2018-06-05 線性表3

十拣播、 約瑟夫問題

據(jù)說著名猶太歷史學家 Josephus有過以下的故事:在羅馬人占領(lǐng)喬塔帕特后发笔,39個猶太人與Josephus及他的朋友躲到一個洞中来吩,39個猶太人決定寧愿死也不要被敵人抓到,于是決定了一個自殺方式尿背,41個人排成一個圓圈,由第1個人開始報數(shù)捶惜,每報數(shù)到第3人該人就必須自殺田藐,然后再由下一個重新報數(shù),直到所有人都自殺身亡為止吱七。
然而Josephus和他的朋友并不想遵從汽久,Josephus要他的朋友先假裝遵從,他將朋友與自己安排在第16個與第31個位置踊餐,于是逃過了這場死亡游戲景醇。

  • 代碼:
//n個人圍圈報數(shù),報m出列市袖,最后剩下的是幾號啡直?
#include <stdio.h>
#include <stdlib.h>
typedef struct node
{
    int data;
    struct node *next;
}node;
node *create(int n)
{
    node *p = NULL, *head;
    head = (node*)malloc(sizeof (node ));
    p = head;
    node *s;
    int i = 1;
    if( 0 != n )
    {
        while( i <= n )
        {
            s = (node *)malloc(sizeof (node));
            s->data = i++;    // 為循環(huán)鏈表初始化,第一個結(jié)點為1苍碟,第二個結(jié)點為2酒觅。
            p->next = s;
            p = s;
        }
        s->next = head->next;
    }
    free(head);
    return s->next ;
}
int main()
{
    int n = 41;
    int m = 3;
    int i;
    node *p = create(n);
    node *temp;
    m %= n;   // m在這里是等于2
    while (p != p->next )
    {
        for (i = 1; i < m-1; i++)
        {
            p = p->next ;
        }
        printf("%d->", p->next->data );
        temp = p->next ;                //刪除第m個節(jié)點
        p->next = temp->next ;
        free(temp);
        p = p->next ;
    }
    printf("%d\n", p->data );
    return 0;
}

作業(yè):編號為1~N的N個人按順時針方向圍坐一圈,每人持有一個密碼(正整數(shù)微峰,可以自由輸入)舷丹,開始人選一個正整數(shù)作為報數(shù)上限值M,從第一個人按順時針方向自1開始順序報數(shù)蜓肆,報道M時停止報數(shù)颜凯。報M的人出列,將他的密碼作為新的M值仗扬,從他順時針方向上的下一個人開始從1報數(shù)症概,如此下去,直至所有人全部出列為止早芭。

#include <stdio.h>
#include <stdlib.h>
#define MAX_NODE_NUM 100
#define TRUE 1U
#define FALSE 0U

typedef struct NodeType
{
    int id;
    int cipher;
    struct NodeType *next;
} NodeType;

/* 創(chuàng)建單向循環(huán)鏈表 */
static void CreaList(NodeType **, const int);
/* 運行"約瑟夫環(huán)"問題 */
static void StatGame(NodeType **, int);
/* 打印循環(huán)鏈表 */
static void PrntList(const NodeType *);
/* 得到一個結(jié)點 */
static NodeType *GetNode(const int, const int);
/* 測試鏈表是否為空, 空為TRUE彼城,非空為FALSE */
static unsigned EmptyList(const NodeType *);

int main(void)
{
    int n, m;
    NodeType *pHead = NULL;
    while (1)
    {
        printf("請輸入人數(shù)n(最多%d個): ", MAX_NODE_NUM);
        scanf("%d", &n);
        printf("和初始密碼m: ");
        scanf("%d", &m);
        if (n > MAX_NODE_NUM)
        {
            printf("人數(shù)太多,請重新輸入退个!\n");
            continue;
        }
        else
            break;
    }
    CreaList(&pHead, n);
    printf("\n------------ 循環(huán)鏈表原始打印 -------------\n");
    PrntList(pHead);
    printf("\n-------------刪除出隊情況打印 -------------\n");
    StatGame(&pHead, m);
}

static void CreaList(NodeType **ppHead, const int n)
{
    int i, iCipher;
    NodeType *pNew, *pCur;
    for (i = 1; i <= n; i++)
    {
        printf("輸入第%d個人的密碼: ", i);
        scanf("%d", &iCipher);
        pNew = GetNode(i, iCipher);
        if (*ppHead == NULL)
        {
            *ppHead = pCur = pNew;
            pCur->next = *ppHead;
        }
        else
        {
            pNew->next = pCur->next;
            pCur->next = pNew;
            pCur = pNew;
        }
    }
    printf("完成單向循環(huán)鏈表的創(chuàng)建!\n");
}

static void StatGame(NodeType **ppHead, int iCipher)
{
    int iCounter, iFlag = 1;
    NodeType *pPrv, *pCur, *pDel;
    pPrv = pCur = *ppHead;
    /* 將pPrv初始為指向尾結(jié)點募壕,為刪除作好準備 */
    while (pPrv->next != *ppHead)
        pPrv = pPrv->next;
    while (iFlag)
    {
        for (iCounter = 1; iCounter < iCipher; iCounter++)
        {
            pPrv = pCur;
            pCur = pCur->next;
        }
        if (pPrv == pCur)
            iFlag = 0;
        pDel = pCur; /* 刪除pCur指向的結(jié)點,即有人出列 */
        pPrv->next = pCur->next;
        pCur = pCur->next;
        iCipher = pDel->cipher;
        printf("第%d個人出列, 密碼: %d\n", pDel->id, pDel->cipher);
        free(pDel);
    }
    *ppHead = NULL;
    getchar();
}

static void PrntList(const NodeType *pHead)
{
    const NodeType *pCur = pHead;
    if (EmptyList(pHead))
        return;
    do
    {
        printf("第%d個人, 密碼: %d\n", pCur->id, pCur->cipher);
        pCur = pCur->next;
    }
    while (pCur != pHead);
    getchar();
}

static NodeType *GetNode(const int iId, const int iCipher)
{
    NodeType *pNew;
    pNew = (NodeType *)malloc(sizeof(NodeType));
    if(!pNew)
    {
        printf("Error, the memory is not enough!\n");
        exit(-1);
    }
    pNew->id = iId;
    pNew->cipher = iCipher;
    pNew->next = NULL;
    return pNew;
}

static unsigned EmptyList(const NodeType *pHead)
{
    if(!pHead)
    {
        printf("The list is empty!\n");
        return TRUE;
    }
    return FALSE;
}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末语盈,一起剝皮案震驚了整個濱河市舱馅,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌刀荒,老刑警劉巖代嗤,帶你破解...
    沈念sama閱讀 219,490評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異缠借,居然都是意外死亡资溃,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評論 3 395
  • 文/潘曉璐 我一進店門烈炭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來溶锭,“玉大人,你說我怎么就攤上這事符隙∨客保” “怎么了?”我有些...
    開封第一講書人閱讀 165,830評論 0 356
  • 文/不壞的土叔 我叫張陵霹疫,是天一觀的道長拱绑。 經(jīng)常有香客問我,道長丽蝎,這世上最難降的妖魔是什么猎拨? 我笑而不...
    開封第一講書人閱讀 58,957評論 1 295
  • 正文 為了忘掉前任膀藐,我火速辦了婚禮,結(jié)果婚禮上红省,老公的妹妹穿的比我還像新娘额各。我一直安慰自己,他們只是感情好吧恃,可當我...
    茶點故事閱讀 67,974評論 6 393
  • 文/花漫 我一把揭開白布虾啦。 她就那樣靜靜地躺著,像睡著了一般痕寓。 火紅的嫁衣襯著肌膚如雪傲醉。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,754評論 1 307
  • 那天呻率,我揣著相機與錄音硬毕,去河邊找鬼。 笑死礼仗,一個胖子當著我的面吹牛昭殉,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播藐守,決...
    沈念sama閱讀 40,464評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼挪丢,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了卢厂?” 一聲冷哼從身側(cè)響起乾蓬,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎慎恒,沒想到半個月后任内,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,847評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡融柬,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,995評論 3 338
  • 正文 我和宋清朗相戀三年死嗦,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片粒氧。...
    茶點故事閱讀 40,137評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡越除,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出外盯,到底是詐尸還是另有隱情摘盆,我是刑警寧澤,帶...
    沈念sama閱讀 35,819評論 5 346
  • 正文 年R本政府宣布饱苟,位于F島的核電站孩擂,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏箱熬。R本人自食惡果不足惜类垦,卻給世界環(huán)境...
    茶點故事閱讀 41,482評論 3 331
  • 文/蒙蒙 一狈邑、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蚤认,春花似錦米苹、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽赤炒。三九已至氯析,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間莺褒,已是汗流浹背掩缓。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留遵岩,地道東北人你辣。 一個月前我還...
    沈念sama閱讀 48,409評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像尘执,于是被迫代替她去往敵國和親舍哄。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,086評論 2 355

推薦閱讀更多精彩內(nèi)容