`

卡片扔掉奇数位 算法

阅读更多
    有N张卡片,标号为从1到N。第一轮抽取到奇数位时,将卡片扔掉,偶数位保留;第二轮扔掉剩下来的奇数位。以此类推,最后剩下的卡片标号为?

1. 列表实现
private static int retrieveLastViaList(int n) {
	LinkedList<Integer> list = new LinkedList<Integer>(); // 构建列表
	for (int i = 1; i <= n; i++) { // 第一轮
		if (i % 2 == 0) {
			list.add(i); // 存放卡片
		}
	}
	boolean bOdd = true; // 奇数位标志
	Iterator<Integer> iter = list.iterator();
	while (true) {
		if (!iter.hasNext()) { // 到卡片尾部了,开始下一轮
			iter = list.iterator();
			bOdd = true; // 重置奇数位标志
		}
		Integer cur = iter.next();
		if (list.size() == 1) { // 卡片只有一张了,是我们需要的
			return cur;
		}
		if (bOdd) { // 奇数位
			iter.remove(); // 扔掉卡片
			bOdd = false; // 切换偶数位
		} else { // 偶数位
			bOdd = true; // 切换奇数位
		}
	}
}


2. 数组实现
private static int retrieveLastViaArray(int n) {
	int[] arr = new int[n]; // 构建数组
	for (int i = 1; i <= n; ++i) {
		arr[i - 1] = i; // 存放卡片
	}
	int cur = 1; // 当前卡片
	int rem = n; // 剩余卡片数
	boolean bOdd = true; // 奇数位标志
	while (true) {
		if (rem == 1) { // 只剩一张卡片
			while (arr[cur - 1] == 0) { // 该卡片已丢弃,定位下一张可用的卡片
				cur++;
				if (cur > n) { // 超过卡片尾部
					cur = 1;
				}
			}
			return cur; // 返回该卡片标号
		}
		while (arr[cur - 1] == 0) { // 该卡片已丢弃,定位下一张可用的卡片
			cur++;
			if (cur > n) { // 超过卡片尾部,开始下一轮
				bOdd = true; // 重置奇数位标志
				cur = 1;
			}
		}
		if (bOdd) { // 奇数位
			arr[cur - 1] = 0; // 置0,表示丢弃
			rem--; // 剩余卡片减一
			bOdd = false; // 切换到偶数位
		} else { // 偶数位
			bOdd = true; // 切换到奇数位
		}
		cur++;
		if (cur > n) { // 超过卡片尾部,开始下一轮
			bOdd = true; // 重置奇数位标志
			cur = 1;
		}
	}
}


逻辑方面,数组比列表复杂,因为数组创建后,长度无法改变,通过置0表示扔掉该卡片。
性能方面,数组比列表要好很多。
分享到:
评论

相关推荐

    数字签名算法,c++实现,RSA的算法

    这里的压缩包文件聚焦于RSA算法的C++实现以及数字签名的相关程序。RSA是一种非对称加密算法,由Ron Rivest、Adi Shamir和Leonard Adleman在1977年提出,因其发明者的名字首字母命名。它广泛应用于数字证书、网络通信...

    mifare系列卡片crapto-1加密算法源码

    其中,Crpto-1算法是Mifare Classic卡中用于数据加密的一种专有算法,它为卡片的数据安全提供了基础保障。本资源包含的是Crpto-1加密算法的源码,可用于理解算法原理或开发与Mifare Classic兼容的读写设备。 Crpto-...

    多位数除法汇编算法(不限位数)

    好久没有上传资料了,这是我前几年开发51单片机时写得多位数除法的一个算法。前两天用了一下。感觉还是那么好用。所以发上来供大家参考。 此算法为汇编,被除数、除数和商的位数都不限,商的小数点后转换为十进制后...

    G-P算法计算关联维数

    G-P算法计算关联维数 G-P算法是一种常用的计算关联维数的方法,该算法由Grassberger和Procaccia于1983年提出的,主要用于计算时间序列的关联维数。关联维数是一种衡量时间序列复杂度的指标,可以反映时间序列的自...

    处理器调度 操作系统 设计一个按优先数调度算法实现处理器调度的程序。

    实验一 处理器调度 一. 实验内容 选择一个调度算法,实现处理器调度。 二. 实验目的 在采用多道程序设计的系统中,...第—题:设计一个按优先数调度算法实现处理器调度的程序。 运行环境:Microsoft Visual Studio 2005

    手写数字识别的几种算法 c 源码

    以下是一些关于手写数字识别的基本概念、常用算法以及如何在C语言中实现这些算法的关键知识点: 1. **预处理**: 在识别手写数字之前,通常需要对图像进行预处理。这包括二值化(将图像转换为黑白)、降噪(去除...

    算法讲解084【必备】数位dp-上.pptx

    算法讲解084【必备】数位dp-上

    模型算法大全(20+种常用算法模型+代码实现)

    模型算法大全(20+种常用算法模型+代码实现)模型算法大全(20+种常用算法模型+代码实现)模型算法大全(20+种常用算法模型+代码实现)模型算法大全(20+种常用算法模型+代码实现)模型算法大全(20+种常用算法模型+...

    数模美赛常用算法集合

    在数模竞赛中,参赛者通常需要解决各种复杂问题,这就需要用到一系列的算法来求解。以下是基于给定的文件信息,对各个算法的详细解释: 1. **分治算法**: 分治策略是将一个大问题分解为若干个相同或相似的小问题...

    扩频通信数字基带信号处理算法及其VLSI实现 PDF

    8. 5 数字非相干双△△DLL跟踪算法及VLSI结构 8. 5. 1 非相干双△DLL跟踪算法描述 8. 5. 2 环路参数设计及部分单元部件的VLSI结构 8. 5. 3 数字式非相干双△DLL的VLSI结构 8. 6 窄相关DLL原理及性能 8. 6. 1 窄相关...

    java算法全卷(包括基本算法和图算法)

    Java算法全卷涵盖了基本算法和图算法,是学习和提升编程技能的重要资源。这份资料主要针对使用Java语言进行算法实现的开发者,适用于那些对ANT、EJB、J2EE、JAVA和SPRING等技术栈有了解或兴趣的人群。下面我们将深入...

    磁盘调度算法(最短寻道时间优先算法(SSTF) 扫描算法(SCAN) 先来先服务算法(FCFS) 循环扫描算法(CSCAN)....)

    常见的磁盘调度算法有先来先服务算法(FCFS)、最短寻道时间优先算法(SSTF)、扫描算法(SCAN)和循环扫描算法(CSCAN)等。 先来先服务算法(FCFS) 先来先服务算法(FCFS)是一种最简单的磁盘调度算法。该算法...

    贝叶斯网络学习算法――k2算法

    K2算法是其中一种用于学习贝叶斯网络结构的算法,尤其适用于小到中等规模的数据集。 K2算法,全称为Cowell-Koller-Komorowski算法,由R. Cowell、M. Koller、A. Komorowski于1994年提出。该算法基于最大后验概率...

    灰狼优化算法和粒子群优化算法比较

    标题中的“灰狼优化算法和粒子群优化算法比较”指的是在优化问题中,对两种流行的启发式算法——灰狼优化算法(Grey Wolf Optimizer, GWO)与粒子群优化算法(Particle Swarm Optimization, PSO)的性能进行分析和...

    二进制数字数据按位取反算法

    对二进制的数字数据,在需要按位取反时,可以直接使用该函数。是效率最优算法。

    操作系统 C++ 页面置换算法(含实验报告)有opt,LRU,先进先出,时钟算法,改进的时钟算法等所有算法

    Clock置换算法:为进入内存的页面设置一个访问位,当内存中某页被访问,访问位置一,算法在选择一页淘汰时,只需检查访问位,若为0,则直接换出,若为1,置该访问位为0,检测内存中的下一个页面的访问位。 改进型...

    RSA算法的纯Python实现

    实现了生成指定数位的密钥对,加密,解密,签名和验证,这5个核心功能。 4、RSAtest.py一个使用RSA算法库的例子。例子从生成密钥对开始,对数据进行加解密,签名和验证签名,最后用修改后的消息再次验证签名。 这个...

    C#实现MD5加密(16位和32位)算法

    c#语言实现的原始MD5加密算法,支持16位加密和32位加密.

    基于遗传算法和模拟退火算法改进的混合模拟退火算法

    基于遗传算法和模拟退火算法改进的混合模拟退火算法(解决求函数极值问题,MATLAB代码已实现)混合模拟退火算法时遗传算法和模拟退火算法的结合,在混合模拟退火算法中使用了大量的样本作为问题的可能解决方案而不是...

    Mersenne Twister 伪随机数生成算法

    Mersenne Twister算法译为马特赛特旋转演算法,是伪随机数发生器之一,其主要作用是生成伪随机数。此算法是Makoto Matsumoto (松本)和Takuji Nishimura (西村)于1997年开发的,基于有限二进制字段上的矩阵线性再生。...

Global site tag (gtag.js) - Google Analytics