欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言數(shù)據(jù)結(jié)構(gòu)中約瑟夫環(huán)問題探究

 更新時間:2023年01月12日 16:30:42   作者:Li&&Tao  
這篇文章主要介紹了C語言數(shù)據(jù)結(jié)構(gòu)中約瑟夫環(huán)問題,總的來說這并不是一道難題,那為什么要拿出這道題介紹?拿出這道題真正想要傳達(dá)的是解題的思路,以及不斷優(yōu)化探尋最優(yōu)解的過程。希望通過這道題能給你帶來一種解題優(yōu)化的思路

數(shù)據(jù)結(jié)構(gòu)開講啦!??!

本專欄包括:

  • 抽象數(shù)據(jù)類型
  • 線性表及其應(yīng)用
  • 棧和隊列及其應(yīng)用
  • 串及其應(yīng)用
  • 數(shù)組和廣義表
  • 樹、圖及其應(yīng)用
  • 存儲管理、查找和排序

將從簡單的抽象數(shù)據(jù)類型出發(fā),深入淺出地講解復(fù)數(shù)

到第二講線性表及其應(yīng)用中會講解,運動會分?jǐn)?shù)統(tǒng)計,約瑟夫環(huán),集合的并、交和差運算,一元稀疏多項式計算器

到最后一步一步學(xué)會利用數(shù)據(jù)結(jié)構(gòu)和算法知識獨立完成校園導(dǎo)航咨詢的程序。

希望我們在學(xué)習(xí)的過程中一起見證彼此的成長。

問題描述

約瑟夫環(huán)問題的一種描述是:將編號為1,2,...n的n個人按順時針方向圍坐一圈,每人持有一個密碼(正整數(shù))。一開始任選一個正整數(shù)作為報數(shù)上限值m,從第一個人開始按順時針方向自1開始順序報數(shù),報道m(xù)時停止報數(shù)。報m的人出列,將他的密碼作為新的m值,從他在順時針方向上的下一個人開始重新從1報數(shù),如此下去,直至所有人全部出列為止。設(shè)計一個程序求出出列順序。

基本要求

利用單向循環(huán)鏈表存儲結(jié)構(gòu)模擬此過程,按照出列的順序印出個人的編號。

測試數(shù)據(jù)

m的初值為20;n = 7,7個人的密碼依次為:3,1,7,2,4,8,4,首先m值為6(正確的出列順序應(yīng)為6,1,4,7,2,3,5)。

實現(xiàn)思路1

用的是數(shù)組索引。結(jié)合一點點的算法知識。

#include<stdlib.h>
#include<stdio.h>
//#用數(shù)組索引的模式 
int main(){
	int m;
	printf("請輸入m的值:");
	scanf("%d",&m);
	int n;
	printf("請輸入n的值:"); 
	scanf("%d",&n);
	int a[100];
	for(int i = 0;i<n;i++){
		scanf("%d",&a[i]);
	}
	int cnt = 0;
	int cnt1 = 0;
	int i = 0;
	while(1){
		if (a[i]!=0){
			cnt++;
			if(cnt==m){
				m = a[i];
				a[i] = 0;
				cnt = 0;
				printf("%d ",i+1);
				cnt1++;
			}
			if(cnt1==n){
				break;
			}
		}
		i = (++i)%n;
	} 
}

實現(xiàn)思路2

利用單項循環(huán)鏈表的方式,上干貨

運用的函數(shù):

  • 創(chuàng)建鏈表
  • 取得鏈表的下標(biāo)
  • 刪除鏈表指定下標(biāo)的元素
  • 得到第i個元素值

數(shù)據(jù)結(jié)構(gòu)的定義:

  • 結(jié)構(gòu)體 LNode,成員包括:原始下標(biāo),元素值
  • 主函數(shù)的思路:

其中上面的函數(shù)都是參考《數(shù)據(jù)結(jié)構(gòu)(C語言版)》上面。只是將創(chuàng)建鏈表的函數(shù)改成創(chuàng)建單向循環(huán)鏈表的函數(shù)。寫代碼主要時間消耗在主函數(shù)上。

主函數(shù)的思路:

創(chuàng)建一個指定大?。╪)的循環(huán)鏈表,每一次循環(huán)得到第m個元素,記錄此元素的下標(biāo),然后移動頭結(jié)點到刪除元素前面的結(jié)點,再把此時的頭節(jié)點后面1一個結(jié)點給刪除。依次遍歷到n個。

#include<stdlib.h>
#include<stdio.h>
//用單項循環(huán)列表的方式 
//數(shù)據(jù)類型的定義 
typedef struct LNode{
	int data;		//定義密碼值 
	int index; 		//定義數(shù)據(jù)的下標(biāo) 
	struct LNode *next;
}LNode,*LinkList;
int GetElem_L(LinkList L,int i ,int &e){
	LNode* p;				//注意這里的*號 
	p = L->next;
	int j = 1;
	while(p&&j<i){
		p = p->next;
		++j;
	} 
	if(!p || j>i)
	{
		return -1;
	}
	e = p->data;
//	printf("%d ",e);
	return e;
}//GetElem_L
int GetIndex_L(LinkList L,int i ,int &e){
	LNode* p;				//注意這里的*號 
	p = L->next;
	int j = 1;
	while(p&&j<i){
		p = p->next;
		++j;
	} 
	if(!p || j>i)
	{
		return -1;
	}
	e = p->index;
//	printf("%d ",e);
	return e;
}//GetIndex_L
int ListDelete_L(LinkList &L,int i,int &e){
	LNode* p;				//注意這里的*號
	p  = L;
	int j = 0;
	while(p->next&&j<i-1){
		p = p->next;
		++j;
	}
	if(!(p->next)||j>i-1){
		return -1;
	}
	LNode* q;
	q = p->next;
	p->next = q->next;
	e = q->data;
	free(q);
	return e; 
}//ListDelete_L
void CreateList_L(LinkList &L,int n){
	L = (LinkList)malloc(sizeof(LNode));
	L->next = NULL;
	LNode* tmp = (LinkList)malloc(sizeof(LNode));
	tmp = L;
	for(int i = 0;i<n-1;++i){
		LNode* p = (LinkList)malloc(sizeof(LNode));
		scanf("%d",&p->data);
		p->index = i+1;
		p->next = tmp->next;
		tmp->next = p;
		tmp = tmp->next;
	}
	LNode* p = (LinkList)malloc(sizeof(LNode));          //注意這里的*號
	scanf("%d",&p->data);
	p->index = n;
	p->next = L->next;
	tmp->next = p;
}//創(chuàng)建循環(huán)鏈表 
int main(){
	int m;
	int cnt;
	printf("請輸入m的值:");
	scanf("%d",&m);
	int n;
	printf("請輸入n的值: "); 
	scanf("%d",&n);
	LNode* L;						//注意這里的*號
	CreateList_L(L,n);	
	int e = 0 ;
	int index = 0;
	for(int i = 0;i<n;i++){
		GetElem_L(L,i+1,e);
	}
	for(int i = 0;i<n;i++){
		int l = 0;
		l = GetIndex_L(L,m,index);
		printf("%d ",l);
		int tmp = GetElem_L(L,m,e);
		for(int i = 0;i<m-1;i++){		
			L = L->next;
		}
		ListDelete_L(L,1,e);
		m =  tmp;
	}
}

結(jié)果

到此這篇關(guān)于C語言數(shù)據(jù)結(jié)構(gòu)中約瑟夫環(huán)問題探究的文章就介紹到這了,更多相關(guān)C語言約瑟夫環(huán)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 創(chuàng)建二叉樹 二叉樹如何刪除節(jié)點操作教程

    創(chuàng)建二叉樹 二叉樹如何刪除節(jié)點操作教程

    本文將詳細(xì)介紹二叉樹的創(chuàng)建,節(jié)點刪除,節(jié)點增加等一系列操作方法,需要的朋友可以參考下
    2012-12-12
  • OpenGL實現(xiàn)貝塞爾曲線或曲面

    OpenGL實現(xiàn)貝塞爾曲線或曲面

    這篇文章主要為大家詳細(xì)介紹了OpenGL實現(xiàn)貝塞爾曲線或曲面,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • C++實現(xiàn)LeetCode(210.課程清單之二)

    C++實現(xiàn)LeetCode(210.課程清單之二)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(210.課程清單之二),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • 二叉樹入門和刷題詳解

    二叉樹入門和刷題詳解

    這篇文章主要介紹了二叉樹入門和刷題詳解的相關(guān)資料,需要的朋友可以參考下
    2023-07-07
  • C語言各種操作符透徹理解上篇

    C語言各種操作符透徹理解上篇

    C 語言提供了豐富的操作符,有:算術(shù)操作符,移位操作符,位操作符,賦值操作符。讓我們通讀本篇來詳細(xì)了解吧
    2022-02-02
  • C語言大小端字節(jié)序存儲模式深入解讀

    C語言大小端字節(jié)序存儲模式深入解讀

    我們知道,當(dāng)編譯器執(zhí)行 “創(chuàng)建變量” 這一代碼時,會在內(nèi)存中開辟空間相應(yīng)的空間來存儲變量值。而對于整型變量而言,變量值又是以二進制補碼的形式存放的
    2022-09-09
  • C++遍歷文件夾下的所有文件

    C++遍歷文件夾下的所有文件

    數(shù)據(jù)分多個文件存儲,讀取數(shù)據(jù)就需要對多個文件進行操作。下面通過實例代碼給大家講解C++遍歷文件夾下的所有文件,感興趣的的朋友一起看看吧
    2017-08-08
  • 解析C++中派生的概念以及派生類成員的訪問屬性

    解析C++中派生的概念以及派生類成員的訪問屬性

    這篇文章主要介紹了解析C++中派生的概念以及派生類成員的訪問屬性,是C++入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-09-09
  • C語言掃雷游戲的簡單實現(xiàn)

    C語言掃雷游戲的簡單實現(xiàn)

    這篇文章主要為大家詳細(xì)介紹了C語言掃雷游戲的簡單實現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • C++示例分析內(nèi)聯(lián)函數(shù)與引用變量及函數(shù)重載的使用

    C++示例分析內(nèi)聯(lián)函數(shù)與引用變量及函數(shù)重載的使用

    為了消除函數(shù)調(diào)用的時空開銷,C++ 提供一種提高效率的方法,即在編譯時將函數(shù)調(diào)用處用函數(shù)體替換,類似于C語言中的宏展開。這種在函數(shù)調(diào)用處直接嵌入函數(shù)體的函數(shù)稱為內(nèi)聯(lián)函數(shù)(Inline Function),又稱內(nèi)嵌函數(shù)或者內(nèi)置函數(shù)
    2022-08-08

最新評論