有一个很出名的数学问题:100个人一起玩一个游戏,每个人游戏一开始都拥有100块钱,每一轮游戏开始后,每一个人都给随机另一个人 1块钱,就这样当玩了100轮,1000轮,10000轮…后,试问最后的财富分布情况
你可能会根据感觉认为 你给别人一块别人给我一块 最后每个人的钱应该都差不多,财富分布应该是一种水平的状况,
然而并不是这样,最后的结果是严重的两级分化,富的富死,穷的穷死
通过Java模拟这个游戏,快速模拟上百万轮游戏,记录变化的值,并用Swing功能将其实现可视化
(以下为游戏刚开始,由100条蓝色矩形组成,每条矩形代表一个人,矩形长度代表拥有的钱数量,刚开始每人为100块)
(以下为动态变化过程)
(为了更好体现数据,即使钱为0了也要给另一个人1块钱,代表负债,红色为负债,蓝色为拥有的钱和债权)
(最终的财富分布图)
总体是呈红蓝两极分布,由于可以负债,导致产生大量债务而不是真正的钱,两边的矩形条都已经突破天际了,左边的人简直不用活了,讽刺至极。
以下是Java代码实现,仅供参考,采用MVC三个类实现
import javax.swing.*;
import java.awt.*;
import java.awt.geom.*;
import java.lang.InterruptedException;
//模型类M
public class AlgoVisHelper {
//用于存储用于调用的基本色
private AlgoVisHelper(){
}
public static final Color Red = new Color(0xF44336);
public static final Color Pink = new Color(0xE91E63);
public static final Color Purple = new Color(0x9C27B0);
public static final Color DeepPurple = new Color(0x673AB7);
public static final Color Indigo = new Color(0x3F51B5);
public static final Color Blue = new Color(0x2196F3);
public static final Color LightBlue = new Color(0x03A9F4);
public static final Color Cyan = new Color(0x00BCD4);
public static final Color Teal = new Color(0x009688);
public static final Color Green = new Color(0x4CAF50);
public static final Color LightGreen = new Color(0x8BC34A);
public static final Color Lime = new Color(0xCDDC39);
public static final Color Yellow = new Color(0xFFEB3B);
public static final Color Amber = new Color(0xFFC107);
public static final Color Orange = new Color(0xFF9800);
public static