首页 > 其他分享 >《约瑟夫问题 循环链表》

《约瑟夫问题 循环链表》

时间:2025-01-04 21:57:59浏览次数:3  
标签:Node head int next 链表 tail 循环 约瑟夫 data

约瑟夫问题循环链表题解来了!!!

#include<bits/stdc++.h>
using namespace std;
int m, n;
struct Node{
	int data;
	Node *next;
} *head, *p, *tail, *temp;
int main(){
	cin>>m>>n;
	head = new Node;
	head -> next = NULL;
	tail = head;
	for(int i = 1; i <= m; i++){
		p = new Node;
		p -> data = i;
		p -> next = NULL;
		tail -> next = p;
		tail = p;
	}
	p = head -> next;
	tail -> next = head -> next;
	for(int i = 1; i <= m; i++){
		for(int j = 1; j < n - 1; j++){
			p = p -> next;
		}
		cout<<p -> next -> data<<" ";
		temp = p -> next;
		p -> next = temp -> next;
		p = p -> next;
		free(temp);
	}
	return 0;
}

标签:Node,head,int,next,链表,tail,循环,约瑟夫,data
From: https://blog.csdn.net/2401_84500159/article/details/144935856

相关文章

  • 19删除链表的倒数第n个结点
    正常思路,先遍历一遍链表得到长度,然后进行第二次遍历得到待删除结点的上一个结点classSolution{public:ListNode*removeNthFromEnd(ListNode*head,intn){ListNode*dummyHead=newListNode(0);dummyHead->next=head;ListNode*cur=......
  • 流程控制第二弹: 从小白到高手-Java While 循环的进阶秘籍(文中有福利赠送)
    ......
  • 24. 两两交换链表中的节点(中)
    目录题目法一、迭代法二、递归题目给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。法一、迭代varswapPairs=function(head){letdummy={next:head}letp1=dummywhil......
  • 15C++循环结构-while循环(2)——教学
    一、while语句的应用(第44课角谷猜想)参考视频1问题:对于每一个正整数,如果它是奇数,则对它乘3再加1,如果它是偶数,则对它除以2,如此循环,最终都能够得到1,这就是由日本数学家角谷静夫发现的角谷猜想,又称为3n+1猜想。如取一个数字6,根据上述公式,得出6→3→10→5→16→8→4→2→1。试编一......
  • list和字典哪个性能高?for循环下哪个性能高?为啥?
    在选择数据结构时,性能取决于具体的操作和使用场景。列表(List)和字典(Dictionary)是两种常见的数据结构,它们有不同的性能特性。以下是对这两种数据结构在不同操作下的性能比较,特别是针对for循环下的性能表现。列表(List)列表是一种有序的集合,通常用于存储一组元素,并按顺序访问这......
  • 循环结构
    循环结构while循环语法:while(布尔表达式){//循环内容}只要表达式为true,循环就会一直执行下去大多数情况会让循环停止下来,需要一个表达式失效的方式来结束循环少部分情况需要循环一直执行,比如服务器的请求相应监听循环条件一直为true就会造成无限循环【死循环】,正常业务......
  • 24 两两交换链表中的节点
    思路简单,但是操作的时候还是要注意细节,特别是某些结点的next指针变化需要格外关注,报了很多次错。因为没注意到:每次替换两个结点后,应该让当前的后面的结点指向下两个结点的靠后一点的结点。主要还是画完图后没有走一遍链表classSolution{public:ListNode*swapPairs(List......
  • 单链表的一些操作(c语言):插入头节点、尾节点、删除某个节点
    #include<stdio.h>#include<stdlib.h>structNode{  intdata;  structNode*Next;  /*data*/};typedefstructNodenode;node*Link;// 创建一个新的节点node*CreateNewNode(intdata){  node*NewNode=(node*)malloc(sizeof(node......
  • 数据结构:循环单链表
    循环单链表(CircularSinglyLinkedList)循环单链表是单链表的一种变体,其特点是链表的尾节点指向头节点,形成一个闭环。这种结构允许在链表中进行无缝的遍历,并且可以从任何节点开始遍历整个链表。循环单链表通常用于需要循环访问元素的场景,如轮询调度、环形缓冲区等。1.节点结......
  • 视频号直播自动回复浏览器插件,帮我自动回评论,也可以不停的循环发评论 vx: llike620
    开启直播以后,一定要在视频号助手后台,有直播管理页面下,就是那个展示评论和能发送评论框的页面,启动插件。要把自己当前发评论的昵称屏蔽掉,否则会捕获到自己回复的,造成死循环。视频号直播在回复时,会自动点击这条评论,然后再点击回复按钮,那么在用户那边看就是单独回复给我的。并且因......