[代码] MapReduce的mainRunner忽略,咱们可根据需要改下输入输出KeyValue的意义 // Mapper
public class PieMapper extends
		Mapper {
	private Random random = new Random();
	 http://www.bbbkp123.info/linked/20130319.do @Override
	protected void map(IntWritable key, LongWritable value, Context context)
			throws IOException, InterruptedException {
		long inside = 0;
		for (int i = 0; i < value.get(); i  ) {
			double a = random.nextDouble();
			double b = random.nextDouble();
			if ((a * a   b * b) <= 1) {
				inside  ;
			}
		}
		context.write(value, new LongWritable(inside));
	}
}
// 输入为第几行(忽略) 本行所算的抛飞镖次数

// Reducer
public class PieReducer extends
		Reducer {
	@Override
	protected void reduce(LongWritable key, Iterable values,
			Context context) throws IOException, InterruptedException {
		long total = 0;
		long inside = 0;
		for (LongWritable value : values) {
			total  = key.get();
			inside  = value.get();
		}
		context.write(key, new DoubleWritable(
				4 * (inside / total)));
	}
}

// 代码大约比较清楚,输出为抛的总次数所对应的算出的圆周率,可以用来对比抛N次所得到的精度。当然Double是非常不精确的,要想更精确则需要从头完成大的浮点类型 http://www.163123.info/linked/20130319.do 
09-25 20:01