`

找到2个丢失的数据

 
阅读更多
从1到100 000 中任意拿掉两个数字,把剩下的99998个数顺序打乱,并且放入数组A中。要求只扫描一遍,把这两个数找出来;可以使用最多不超过5个局部变量,不能使用数组变量,并且不能改变原数组的值。
package com.java.examples.digui;

import java.math.BigInteger;
import java.util.Arrays;
import java.util.HashSet;

/**
 * 从1到100 000 中任意拿掉两个数字,把剩下的99998个数顺序打乱,并且放入数组A中。
 * 要求只扫描一遍,把这两个数找出来;可以使用最多不超过5个局部变量,不能使用数组变量,并且不能改变原数组的值。
 * 
 * @author yuahan
 * 
 */
public class FindMissing2Numbers {

	/**
	 * 大数的开方运算
	 * @param theNumber
	 * @return
	 */
	private static BigInteger sqrt(String theNumber) {
		int length = theNumber.length(), i;
		BigInteger res = BigInteger.ZERO;
		BigInteger twenty = BigInteger.valueOf(20);
		BigInteger t, x = BigInteger.ZERO, v, few = BigInteger.ZERO;
		BigInteger hg = BigInteger.valueOf(100);

		String tmpString = null;
		int pos = 2 - length % 2;
		tmpString = theNumber.substring(0, pos);
		while (true) {
			v = few.multiply(hg).add(BigInteger.valueOf(Integer.parseInt(tmpString)));
			if (res.compareTo(BigInteger.ZERO) == 0)
				i = 9;
			else
				i = v.divide(res.multiply(twenty)).intValue();
			for (; i >= 0; i--) {
				t = res.multiply(twenty).add(BigInteger.valueOf(i)).multiply(BigInteger.valueOf(i));
				if (t.compareTo(v) <= 0) {
					x = t;
					break;
				}
			}
			res = res.multiply(BigInteger.TEN).add(BigInteger.valueOf(i));
			few = v.subtract(x);
			pos++;
			if (pos > length)
				break;
			tmpString = theNumber.substring(pos - 1, ++pos);
		}
		return res;
	}

	/**
	 * 逐一比较。但是这个不满足要求。不止一次的扫描数组。
	 * @param array
	 */
	public static void test1(int[] array){
		Arrays.sort(array);
		
		int off = 1;
		for(int i=1;i<=(array.length + 2);i++){
			int index = i - off;
			if(index >= array.length){
				index = array.length - 1;
			}
			if(i - array[index] != 0){
				System.out.println(i);
				off++;
				continue;
			}
		}
	}
	
	/**
	 * 在大概40000左右的时候,经过几十秒的时间可以找到,但是更大的时候便不准确。可能是由于sqrt非常非常大的数的时候出现的问题。
	 * 用到了数学中的这个原理: 
	 * a + b = he
	 * a * b = ji
	 * 通过方程组转变成一元二次方程来解a 和 b。
	 * @param array
	 */
	public static void test2(int[] array){
		BigInteger he = BigInteger.ZERO;
		BigInteger ji = BigInteger.ONE;

		BigInteger he_array = BigInteger.ZERO;
		BigInteger ji_array = BigInteger.ONE;

		he = new BigInteger(((array.length + 2) * (array.length + 3) / 2) + "");

		for (int i = 1; i <= array.length + 2; i++) {
			ji = ji.multiply(new BigInteger(String.valueOf(i)));
		}

		for (int i = 0; i < array.length; i++) {
			he_array = he_array.add(new BigInteger(String.valueOf(array[i])));
			ji_array = ji_array.multiply(new BigInteger(String.valueOf(array[i])));
		}

		he = he.subtract(he_array);
		ji = ji.divide(ji_array);
		BigInteger temp = sqrt(he.pow(2).subtract(ji.multiply(new BigInteger("4"))).toString());
		;
		System.out.println((he.add(temp)).divide(new BigInteger("2")));
		System.out.println((he.subtract(temp)).divide(new BigInteger("2")));
	}
	
	/**
	 * 正确的方法。简单,快速。
	 * @param array
	 */
	public static void test3(int[] array){
		HashSet<Integer> set = new HashSet<Integer>(array.length);
		for(int i : array){
			set.add(i);
		}
		
		for(int i=1;i<=(array.length + 2);i++){
			if(!set.contains(i)){
				System.out.println(i);
			}
		}
	}
	
	public static void main(String[] args) {
//		int[] array = {1,2,3,4,5,6,7,8,9,10,11,12,13};
//		test3(array);
	}
}


分享到:
评论

相关推荐

    9个步骤恢复格式化数据,删除数据,丢失数据

    ### 9个步骤恢复格式化数据、删除数据与丢失数据 #### 一、引言 在数字时代,数据丢失已成为用户普遍面临的问题之一。无论是由于误操作还是硬件故障导致的数据丢失,都可能对个人或企业造成严重影响。因此,掌握...

    丢失数据快速恢复软件

    2. **预览功能**:在恢复文件之前,用户通常可以预览找到的文件内容,确保它们是需要恢复的目标文件,避免盲目恢复导致的错误。 3. **支持多种文件类型**:高质量的恢复软件能支持恢复各种类型的文件,如文档、图片...

    JS中利用localStorage防止页面动态添加数据刷新后数据丢失

    为了解决这个问题,开发者可以利用Web Storage API中的localStorage功能来存储临时数据,防止页面刷新后数据丢失。 ### localStorage简介 localStorage是Web Storage API的一部分,它提供了一种在客户端浏览器存储...

    分区丢失的数据恢复方法

    在IT领域,数据丢失是一个常见的问题,尤其是在存储设备如硬盘、SSD或USB驱动器上。当分区丢失时,这可能会导致用户无法访问存储在该分区上的文件和数据。本篇将详细介绍分区丢失的数据恢复方法,并提供一些实用的...

    EF盘突然丢失的数据恢复软件

    1. **分区恢复**:当EF盘或其他分区意外消失时,该软件能扫描硬盘,找到丢失的分区信息,并尝试恢复其结构和数据。 2. **数据恢复**:即使分区丢失,软件也能深入硬盘扇区,查找并恢复未被覆盖的数据,包括文档、...

    SQL并行更新时丢失数据实例

    在数据库管理领域,SQL并行更新是一个常见的性能优化策略,特别是在处理大数据量或者复杂查询时。然而,这种并行执行模式也可能带来数据一致性问题,如标题所提的“SQL并行更新时丢失数据实例”。本篇文章将深入探讨...

    C实现因格式化而丢失数据的恢复.7z

    本项目名为"C实现因格式化而丢失数据的恢复",它提供了一个Unformat程序,专门针对这种情况,帮助用户找回被格式化的数据。这个程序的亮点在于它支持超过200GB的大硬盘,这在当今大数据的时代显得尤为重要。 首先,...

    还原系统分区合并数据丢失的恢复方法

    在IT领域,数据恢复是一项至关重要的技能,尤其是在遭遇意外情况如系统还原或分区合并后导致的数据丢失。本文将详细介绍一种针对“还原系统分区合并数据丢失”的恢复方法。 首先,问题的起因是用户使用系统自带的...

    Windows2003分区丢失数据恢复工具 R-Studio

    正好公司运行程序又全在那个分区,悲催的搞了2天,还好找到了这个软件,恢复的数据还能用,不然悲催了,哈哈~~装了服务器系统的兄弟如果丢失分区了,建议拷回去试试,不过恢复数据都是看rp的,还是平时勤快点的好

    大数据post提交数据丢失,问题.docx

    2. **网络传输问题**:在网络不稳定时,大数据量的传输可能会导致部分数据丢失。确保网络环境稳定,并使用可靠的传输机制。 3. **编码格式不一致**:客户端和服务器之间编码格式不匹配可能导致数据乱码,从而看似...

    超级数据恢复,丢失数据的克星

    因此,在新的数据覆盖这些位置之前,数据恢复工具可以找到并恢复这些未被覆盖的原始数据。 "超级数据恢复"可能采用了深度扫描和文件预览功能。深度扫描能够逐扇区扫描整个硬盘,寻找已被删除文件的痕迹;而文件预览...

    C/C++ 数据恢复原理与实现

    在这个过程中,关键的步骤包括分析存储介质(如硬盘、闪存驱动器等),识别文件系统结构,定位丢失的文件片段,并尝试重组这些片段以恢复原始数据。 在C/C++中实现数据恢复,需要掌握以下几个核心知识点: 1. **...

    MiniTool数据恢复工具免费版PowerDataRecovery_7.1-数据恢复软件,恢复我剪切过程中丢失的照片,免费版最多能恢复2G

    2. **“深度扫描”**:当常规扫描无法找到丢失的文件时,深度扫描会进行全面的扇区级扫描,虽然耗时较长,但能发现更多可能丢失的文件。 3. **“分区恢复”**:如果你的分区出现错误或被格式化,这个选项可以帮助你...

    分区丢失了数据怎么恢复

    ### 分区丢失了数据怎么恢复 #### 背景与问题描述 在日常使用电脑的过程中,用户可能会遇到一些意外情况导致重要数据丢失。比如,在本文案例中,一位用户因为不小心或者未知原因导致硬盘上的多个分区消失,只留下...

    金山数据恢复大师怎么恢复丢失数据?.docx

    金山数据恢复大师是一款专业的数据恢复软件,用于帮助用户找回意外丢失的文件。下面将详细介绍如何使用这款工具来恢复丢失的数据。 首先,恢复丢失数据的第一步是下载并安装金山数据恢复大师。用户可以从官方渠道...

    重装系统分区丢失只剩一个盘的数据恢复方法

    ### 重装系统分区丢失只剩一个盘的数据恢复方法 #### 背景介绍 在进行系统重装过程中,用户可能会因为误操作导致原本存在的多个分区(如D、E、F等)仅剩下一个分区(通常是C盘),这不仅会导致原有分区的结构丢失,...

    丢失分区数据恢复方法?.docx

    因此,要想恢复丢失分区中存放的数据,可以采取使用十六进制编辑器手动分析硬盘中数据信息的方式,直接找到丢失分区中存放数据的区域,然后对丢失分区中存放的重要数据进行恢复。 MiniTool 数据恢复工具为大家提供...

    用Oracle闪回功能恢复偶然丢失的数据

    2. 数据库使用回滚段中的信息构建一个只读的旧数据视图。 3. 用户检查这个视图,找到误操作的数据。 4. 用户根据需要进行恢复,如重新插入删除的记录。 在实际应用中,闪回功能在多个场景下都发挥了重要作用,例如...

    数据恢复技术深度揭秘

    数据恢复技术是信息技术领域中的一个重要分支,它涉及到对丢失、损坏或不可访问的数据进行恢复,以便重新获得对这些数据的访问。在这个深度揭秘的过程中,我们将探讨数据恢复的关键概念、技术方法以及常见应用场景。...

    电脑DEF盘分区全部丢失的数据恢复方法

    2. **停止写入新数据**:避免向出现问题的硬盘写入新的数据,因为新写入的数据可能会覆盖已丢失的数据,从而降低数据恢复的成功率。 3. **选择合适的数据恢复软件**:使用可靠且功能强大的数据恢复软件是成功恢复...

Global site tag (gtag.js) - Google Analytics