环形链表解决约瑟夫问题
php代码:
//环形链表 /* 解决约瑟夫问题 设定编号1-n个人 约定起始编号k的人从1开始报数,报到m的那个人出列。他的下一位又从1开始报数,数到M的那个人又出列, 依次类推,直到所有人都出列为止,求出列顺序,和最后出列编号 */ header("content-type:text/html;charset=utf-8"); class Child{ public $no; public $next=null; public function __construct($no){ $this->no=$no; } } function addChild(&$first,$n) { $cur=null; for($i=0;$i<=$n-1;$i++){ $child = new child($i+1); if($i==0){ $first = $child; $first->next=$child; $cur=$first; }else{ $cur->next=$child; $child->next=$first; $cur=$cur->next; } } } function showChild($first){ $cur=$first; while($cur->next != $first){ echo $cur->no; $cur=$cur->next; } echo $cur->no; } function countChild($first,$m,$k) { $tail=$first; //考虑从第几个孩子开始 for($i=0;$i<$m-1;$i++){ $tail=$tail->next; } while($tail->next!=$tail) //剔除到链表中只有一个元素为止 { for($i=0;$i<$k-1;$i++){ $cur=$tail;//记录他的前一个位置 $tail=$tail->next; } echo '出列人'.$tail->no; $cur->next=$tail->next; $tail=$tail->next; } echo '111'.$tail->no; } addChild($first,10); showChild($first); echo "<hr/>"; countChild($first,2,3); //第二个小孩开始数,数到三出列
로그인 후 복사
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사
R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
2 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
스플릿 소설을이기는 데 얼마나 걸립니까?
1 몇 달 전
By DDD
R.E.P.O. 최고의 그래픽 설정
2 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
어 ass 신 크리드 그림자 : 조개 수수께끼 솔루션
1 몇 주 전
By DDD
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
2 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제
Gmail 이메일의 로그인 입구는 어디에 있나요?
7403
15


자바 튜토리얼
1630
14


Cakephp 튜토리얼
1358
52


라라벨 튜토리얼
1268
25


PHP 튜토리얼
1218
29

