`

编程珠玑 12章取样问题

 
阅读更多

输入:整数m,n

输出:成0~n-1内的m个不重复的随机整数,要求按序输出,并且保证每个子集被选中的可能性相等。

伪代码:

            select = m 

            remaining = n

            for i = (0]

                if(bigrand()%remaining) < select

                print i

                select --

           remainning --

书中p120页中的主要思想是利用《计算机程序设计艺术第2卷 半数值算法》中给出了伪代码生成数值的等概率性。下面给出java实现代码

 

package org.mino.sort;

import java.io.BufferedWriter;
import java.io.FileNotFoundException;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Random;

/**
 * 随机获取有序数
 * @author DingJie
 */
public class RandomOrderNum {

	/**
	 * @param args
	 * @throws IOException 
	 */
	public static void main(String[] args) throws IOException {
		long beginTime = System.currentTimeMillis();
		FileWriter fw = null;
		BufferedWriter bw = null;
		try {
			fw = new FileWriter("D:/randomOrderNum.txt");
			bw = new BufferedWriter(fw);
			RandomOrderNum.getOrderRandomNum(999, 1000000, bw);
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} finally {
			if(bw != null) {
				bw.flush();
				bw.close();
			} 
			/*if(fw != null) {
				fw.flush();
				fw.close();
			}*/
		}
		long endTime = System.currentTimeMillis();
		System.out.println("总共用时(秒):" + (endTime - beginTime) /1000);
	}
	
	/**
	 * 获取随机数
	 * @param m
	 * @param n
	 * @param ow
	 */
	public static void getOrderRandomNum(int m, int n, BufferedWriter bw) {
		Random rand = new Random(1000000);
		for(int i=0; i < n ; i++) {
			int randInt = Math.abs(rand.nextInt());
			if(randInt % (n-i) < m) {
//				System.out.println(" random: "+randInt % (n-i));
				try {
					bw.write(String.format("%d", i));
					System.out.println(i);
					bw.newLine();
					bw.flush();
				} catch (IOException e) {
					e.printStackTrace();
				}
				m --;
			}
		}
	}

}

 还有一种方法是通过m维数组,指定初始值为数组下标值的大小,然后对每一下标的值与等概率生成的下标进行交换。

 

package org.mino.perl;


import java.io.FileNotFoundException;
import java.io.PrintWriter;
import java.util.Random;

/**
 * 随机产生1-n的m个数
 * @author DingJie
 */
public class RandomGenerate {
	public static void main(String[] args) {
		if (args.length == 0) {
			System.out.println("请输入两个整形参数 例如 9999 1000000 ");
			return;
		}
		int m = Integer.parseInt(args[0]);
		int n = Integer.parseInt(args[1]);
		long l1 = System.currentTimeMillis();
		try {
			PrintWriter pw = new PrintWriter("D:/randomOrderNum.txt");
			random(m, n, pw);//将随机数输出
			pw.close();
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		}
		long l2 = System.currentTimeMillis();
		System.out.println("time:" + (l2 - l1));

	}

	static int randInt(int i, int j, Random rand) {
		if (i < j)
			return i + rand.nextInt(j - i + 1);
		return i;
	}

	/**
	 * 随机数输出到文件
	 * @param m
	 * @param n
	 * @param pw
	 */
	static void random(int m, int n, PrintWriter pw) {
		int[] array = new int[n];//最大的数组
		Random rand = new Random(System.currentTimeMillis());
		System.out.println(System.currentTimeMillis());
		for (int i = 0; i < n; i++)
			array[i] = i + 1;    //赋初值
	
		for (int i = 0; i < m; i++) {
			int j = randInt(i, n - 1, rand);//返回从i 到n-1之间的任意随机数
			int temp = array[j];
			array[j] = array[i];
			array[i] = temp;
		}
		for (int i = 0; i < m; i++) {
			pw.println(array[i]);
		}
		pw.flush();
	}
}

 

分享到:
评论

相关推荐

    编程珠玑 编程珠玑 编程珠玑 编程

    书中涵盖了一系列实用的编程问题和解决方案,这些“珠玑”般的编程智慧,无论对于初学者还是经验丰富的开发者,都有着极高的参考价值。 编程珠玑的核心概念之一是数据结构与算法的选择和设计。书中的例子多以实际...

    编程珠玑源码下载编程珠玑书后源代码

    3. **问题解决策略**:书中提出了解决编程问题的一些通用方法,如预处理、分治法、动态规划等,帮助读者建立系统化的思维模式。 4. **性能分析**:讲解如何分析和改进程序性能,包括时间复杂度和空间复杂度的计算,...

    编程珠玑 第2版(修订版)_编程珠玑修订_资料_

    《编程珠玑》一书将这些技巧和经验整理成章,涵盖了算法、数据结构、性能优化、代码质量等多个方面,是程序员自我提升的重要参考资料。书中强调的问题求解策略和程序设计思想,对于初学者和资深开发者都有很大的启发...

    编程珠玑(第二版)答案

    根据提供的标题“编程珠玑(第二版)答案”和描述“编程珠玑(第二版)答案”,我们可以推测出这是关于《编程珠玑》这本书的相关解答资料。《编程珠玑》是一本经典的计算机科学书籍,作者为Jon Bentley。本书旨在...

    编程珠玑(续)

    《编程珠玑(续)》是计算机科学方面的经典名著《编程珠玑》的姊妹篇,讲述了对于程序员有共性的知识。书中涵盖了程序员操纵程序的技术、程序员取舍的技巧、输入和输出设计以及算法示例,这些内容组成一个有机的整体,...

    编程珠玑 编程珠玑续

    在《编程珠玑》中,作者Jon Bentley将编程问题比喻为“珍珠”,强调解决这些问题的过程如同寻找珍贵的珍珠,需要深思熟虑和精心打磨。书中的主要知识点包括: 1. **问题解决策略**:如何分析问题,确定合适的算法,...

    编程珠玑.pdf

    第12章 对调查的研究 113 12.1 有关民意调查的问题 113 12.2 语言 114 12.3 图片 117 12.4 原理 119 12.5 习题 120 第四部分 算 法 第13章 绝妙的取样 123 13.1 取样算法一瞥 123 13.2 Floyd算法 124 13.3 随机排列 ...

    编程珠玑高清pdf版.pdf

    这本书的核心理念是通过实际的编程问题来传授如何高效地设计和分析算法,旨在提升程序员的问题解决能力,尤其是处理大数据量时的效率。 在描述中提到的"高清pdf版"表明这是一份高质量的电子版,适合在电脑或移动...

    编程珠玑续本

    编程珠玑续、编程珠玑续本、编程珠玑续本、编程珠玑续本

    编程珠玑 Programming Pearls 第二版(中文版+源代码)

    1. **问题解决策略**:书中通过一系列精心设计的编程问题,引导读者学习如何有效地分析问题,找出最优解。这些问题通常涉及数据结构的选择、算法效率的提升以及资源的优化利用。 2. **算法设计与分析**:《编程珠玑...

    编程珠玑第2版pdf

    算法经典书籍编程珠玑第2版,这本书除了讲算法,更是讲述解决问题的思想。

    编程珠玑及其源码

    为此,本书给出了一些精心设计的有趣而且颇具指导意义的程序,这些程序能够为那些复杂的编程问题提供清晰而且完备的解决思路,书中还充满了对实用程序设计技巧及基本设计原则的清晰而睿智的描述。

    编程珠玑(第2版)中文版pdf

    《编程珠玑》不仅关注理论和方法,更强调实际问题的解决,通过一系列精选的程序设计问题,向读者展示了如何在程序设计中应用理论知识,并在面对具体问题时采取合理的解决方案。 书中提到的C#(读作C Sharp)是一种...

    编程珠玑(PDF带目录)

    这不仅是对数据结构的深入学习,也是对编程思维的锻炼,因为正确选择数据结构对于解决编程问题至关重要。 同时,《编程珠玑》强调了搜索算法的重要性,如二分查找、广度优先搜索和深度优先搜索等,这些是处理复杂...

    《编程珠玑》源代码

    《编程珠玑》第一版是我早期职业生涯中阅读过的对我影响较大的书籍之一,在书中首次接触到的很多观点都让我长期受益。作者在这一版本中做了重要更新。新增加的很多例子让我耳目一新。 ——Steve McConnell,《代码...

    编程珠玑之第二章questionC 测试数据

    "第二章questionC"提及的问题是关于"求变位词",这是一个常见的字符串处理问题,涉及到字符统计、排序以及字符串比较等基础知识。 变位词,又称为同字母异序词,是指两个或多个单词由完全相同的字母组成,但字母...

    编程珠玑源代码

    《编程珠玑》是计算机科学领域的一本经典著作,作者是Jon Bentley,它以其深入浅出的讲解方式,探讨了程序设计中的一些核心问题。这本书不仅涵盖了算法和数据结构,还涉及了问题解决、程序效率优化以及软件工程的...

    编程珠玑II(编程珠玑·续) 扫描版6.56M pdf格式

    编程珠玑II(编程珠玑·续) 扫描版6.56M pdf格式

Global site tag (gtag.js) - Google Analytics