91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

如何使用c語言實現約瑟夫問題

小億
112
2024-03-19 16:44:42
欄目: 編程語言

約瑟夫問題是一個經典的數學問題,可以使用C語言來實現。下面是一個簡單的C語言實現約瑟夫問題的示例代碼:

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

// 定義循環鏈表的節點結構體
typedef struct Node {
    int data;
    struct Node* next;
} Node;

// 創建循環鏈表
Node* createCircularLinkedList(int n) {
    Node* head = NULL;
    Node* prev = NULL;
    
    for (int i = 1; i <= n; i++) {
        Node* newNode = (Node*)malloc(sizeof(Node));
        newNode->data = i;
        newNode->next = NULL;
        
        if (head == NULL) {
            head = newNode;
        } else {
            prev->next = newNode;
        }
        
        prev = newNode;
    }
    
    prev->next = head; // 將最后一個節點的next指向頭節點,形成循環
    
    return head;
}

// 解決約瑟夫問題
int josephus(int n, int k) {
    Node* head = createCircularLinkedList(n);
    Node* current = head;
    Node* prev = NULL;
    
    // 找到要刪除的節點的前一個節點
    while (current->next != current) {
        for (int i = 1; i < k; i++) {
            prev = current;
            current = current->next;
        }
        
        Node* temp = current;
        prev->next = current->next;
        current = current->next;
        free(temp);
    }
    
    int result = current->data;
    free(current);
    
    return result;
}

int main() {
    int n = 5; // 總共有5個人
    int k = 2; // 每次報數為2
    
    int survivor = josephus(n, k);
    
    printf("Survivor: %d\n", survivor);
    
    return 0;
}

在上面的代碼中,首先定義了一個循環鏈表的節點結構體,然后實現了創建循環鏈表和解決約瑟夫問題的函數。在main函數中,可以指定總共的人數n和每次報數的數字k,然后調用josephus函數來計算最后幸存者的編號。最后打印出最后幸存者的編號即可。

0
郴州市| 乐东| 天峨县| 汉沽区| 卓资县| 宁都县| 大悟县| 井冈山市| 广宁县| 阿坝县| 偃师市| 河津市| 峨山| 临泉县| 石家庄市| 陆河县| 新平| 桦南县| 临沧市| 甘泉县| 克东县| 泽库县| 宜阳县| 宁阳县| 上思县| 潜江市| 镇平县| 绥棱县| 武强县| 会宁县| 满洲里市| 临城县| 易门县| 武宣县| 肇东市| 盐山县| 贵定县| 莱西市| 台南市| 清远市| 哈密市|