剑指offer系列52---约瑟夫环问题

【题目】0,1,。。。n排成一个圈,从0开始每次删除第m个数,求圆圈最后个数。
* 【思路】1 用数组模拟圆圈。当数到最后一个数即index==n时,令index==0 重头开始遍历;
* 当遇到已经被删除的数时nums[index]==-1,跳过继续;
* 当走到指定m个数的时候,就将其删除掉,nums[index]=-1;

 1 package com.exe10.offer;
 2
 3 /**
 4  * 【题目】0,1,。。。n排成一个圈,从0开始每次删除第m个数,求圆圈最后个数。
 5  * 【思路】1 用数组模拟圆圈。当数到最后一个数即index==n时,令index==0 重头开始遍历;
 6  *                           当遇到已经被删除的数时nums[index]==-1,跳过继续;
 7  *                          当走到指定m个数的时候,就将其删除掉,nums[index]=-1;
 8  * @author WGS
 9  *
10  */
11 public class LastNumberInCircle {
12
13     public int lastRemainInCircle(int n,int m){
14         if(m<1 || n<1) return -1;
15         int[] nums=new int[n];
16         int indexInNums=-1;
17         int count=0;//计步器
18         int length=n;
19         while(length>0){
20             indexInNums++;
21             //1
22             if(indexInNums==n)
23                 indexInNums=0;
24             //2
25             if(nums[indexInNums]==-1)
26                 continue;
27             count++;//计步器++;
28             //3
29             if(count==m){
30                 nums[indexInNums]=-1;
31                 count=0;
32                 length--;
33             }
34         }
35         return indexInNums;
36
37     }
38
39
40     public static void main(String[] args) {
41         int l = new LastNumberInCircle().lastRemainInCircle(5, 3);
42         System.out.println(l);
43     }
44
45 }
时间: 2024-11-08 17:05:39

剑指offer系列52---约瑟夫环问题的相关文章

剑指Offer系列之题11~题15

目录 11.矩形覆盖 12.二进制中1的个数 13. 数值的整数次方 14.调整数组顺序使奇数位于偶数前面 15.链表中倒数第k个结点 11.矩形覆盖 我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形.请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法? 比如n=3时,2*3的矩形块有3种覆盖方法: 斐波那契数列的应用 第一次竖着放一块类比为走一步,第一次横着放两块类比为走两步 代码与上面的斐波那契数列类题目类似,此处不再赘述:剑指Offer系列之题6~题10. 12.

剑指offer系列10:合并两个排序的链表

我拿到这个题的时候举的例子是链表1:1.3.5.7和链表2:2.4.6.8.我的思路是以:1为基础,将表2的每个结点插入表1.也就是说我一次性是要给新建立的链表中加入两个元素,分别是两个原始链表的头结点.这个思路我做了半天头脑一片混乱,中间指针实在不知道怎么弄了.于是我去睡了一觉,哈哈,我大概是这个世界上最会逃避的人了…… 看了答案使用了递归的方法,其实我做的时候我有想到要用递归,但是没用的原因是我一般写代码不喜欢用递归,原因有两个,一个是递归容易死循环,一个是递归的复杂度太高.但这道题真的太适

剑指offer系列4:斐波那契数列

剑指offer第九题,这个题很古老了.第一个想到的肯定是递归,很简单. 1 #include<iostream> 2 #include<vector> 3 using namespace std; 4 class Solution { 5 public: 6 int Fibonacci(int n) { 7 if (n == 0) 8 { 9 return 0; 10 } 11 if (n==1||n==2) 12 { 13 return 1; 14 } 15 else 16 {

剑指offer系列47:堆成的二叉树

这个题的主要思路是: 用二叉树的左子树的右子树和右子树的左子树比较,再用左子树的左子树和右子树的右子树比较.(好像有点绕,但其实就是堆成的思想) 剑指offer的说法是用数的前序遍历的两个方法,前序遍历应该是:根->左->右.但是我们用另一种前序遍历:根->右->左.如果这两个序列一样就判断它是对称的. 这两个方法在实现上其实是一样的. 1 class Solution { 2 public: 3 bool isSymmetrical(TreeNode* pRoot) 4 { 5

剑指offer系列——48.不用加减乘除做加法

Q:写一个函数,求两个整数之和,要求在函数体内不得使用+.-.*./四则运算符号. T: 1.使用进制. 两个数异或:相当于每一位相加,而不考虑进位: 两个数相与,并左移一位:相当于求得进位: 将上述两步的结果相加 首先看十进制是如何做的: 5+7=12,三步走 第一步:相加各位的值,不算进位,得到2. 第二步:计算进位值,得到10. 如果这一步的进位值为0,那么第一步得到的值就是最终结果. 第三步:重复上述两步,只是相加的值变成上述两步的得到的结果2和10,得到12. 同样我们可以用三步走的方

剑指offer系列源码-圆圈中最后剩下的数

题目1356:孩子们的游戏(圆圈中最后剩下的数) 时间限制:10 秒内存限制:32 兆特殊判题:否提交:1073解决:391 题目描述: 每年六一儿童节,JOBDU都会准备一些小礼物去看望孤儿院的小朋友,今年亦是如此.HF作为JOBDU的资深元老,自然也准备了一些小游戏.其中,有个游戏是这样的:首先,让小朋友们围成一个大圈.然后,他随机指定一个数m,让编号为1的小朋友开始报数.每次喊到m的那个小朋友要出列唱首歌,然后可以在礼品箱中任意的挑选礼物,并且不再回到圈中,从他的下一个小朋友开始,继续1.

剑指offer系列26--正则表达式匹配

[题目]请实现一个函数用来匹配包括’.’和’*‘的正则表达式.模式中的字符’.’表示任意一个字符,而’‘表示它前面的字符可以出现任意次(包含0次). 在本题中,匹配是指字符串的所有字符匹配整个模式.例如,字符串”aaa”与模式”a.a”和”abaca”匹配,但是与”aa.a”和”aba”均不匹配 1 package com.exe6.offer; 2 /** 3 * [题目]请实现一个函数用来匹配包括’.’和’*‘的正则表达式.模式中的字符’.’表示任意一个字符, 4 * 而’‘表示它前面的字符

剑指offer系列29-----链表中环的入口节点-

[题目]一个链表中包含环,请找出该链表的环的入口结点. [思路]方法一:使用双指针 方法二:利用set集合的特性,不能添加重复数字,否则返回false 1 package com.exe7.offer; 2 3 /** 4 * [题目]一个链表中包含环,请找出该链表的环的入口结点. 5 * @author WGS 6 * 7 */ 8 public class EntryNodeOfLoop { 9 10 11 class LinkNode{ 12 int val; 13 LinkNode ne

剑指offer系列27--表示数值的字符串

[题目]请实现一个函数用来判断字符串是否表示数值(包括整数和小数). 例如,字符串”+100”,”5e2”,”-123”,”3.1416”和”-1E-16”都表示数值. 但是”12e”,”1a3.14”,”1.2.3”,”+-5”和”12e+4.3”都不是. 1 package com.exe6.offer; 2 /**[题目] 3 * 请实现一个函数用来判断字符串是否表示数值(包括整数和小数). 4 * 例如,字符串”+100”,”5e2”,”-123”,”3.1416”和”-1E-16”都表

剑指offer系列43---判断平衡二叉树

[题目]判断一颗二叉树是不是平衡二叉树. * 平衡二叉树定义:任意子节点深度相差不超过1.[思路]由上题,利用递归得到二叉树每个结点的深度同时比较. 1 package com.exe9.offer; 2 3 import com.exe9.offer.BTreeDepth.TreeNode; 4 5 /** 6 * [题目]判断一颗二叉树是不是平衡二叉树. 7 * 平衡二叉树定义:任意子节点深度相差不超过1. 8 * [思路]由上题,利用递归得到二叉树每个结点的深度同时比较. 9 * @aut