对于本周的任务,我们的任务是编写代码来开发一个程序,该程序使用 StdDraw 库打印一系列正方形,这些正方形产生埃拉托色尼筛子的图形模拟,类似于此 wiki 页面上的那个:
(http://en.wikipedia.org/wiki/Sieve_of_Eratosthenes)
我可以使用的程序本身,尽管对于超过 100 的数字,方块会从屏幕上运行。我可以按原样提交代码,但 id 更喜欢让代码能够将程序缩放到输入的平方量,尽管我在划分正确缩放标准绘制 Java 窗口的算法时遇到问题。
我尝试将用户输入除以 1000 多个并将其添加到X_MAX轴并从Y_MIN轴中减去它,以创建一个捏合比例类型方法,但这并不完美,我也尝试使其呈指数,尽管这也不起作用。
知道我可以使用什么算法来正确缩放窗口以适应用户输入的任何数量的正方形吗?
我的代码在下面,适合任何好奇的人
谢谢
http://pastebin.com/L381yQUZ
加工:https://i.stack.imgur.com/HGzJY.jpg不工作:https://i.stack.imgur.com/SpVoE.jpg
看起来"比例"定义了用户坐标系,因此您需要计算筛子的尺寸,然后设置坐标系,使筛子位于中间,也许周围有一点填充物。
在绘制正方形之前,在 main()
方法中,您需要这样的东西:
double columnWidth = 0.105;
double columnCount = Math.sqrt(input);
double sieveWidth = columnCount * columnWidth;
double sieveHeight = sieveWidth;
double sieveTop = 0.95;
double sieveLeft = 0.045;
double padding = 0.15;
StdDraw.setXscale(sieveLeft - padding, sieveLeft + sieveWidth + padding);
StdDraw.setYscale(sieveTop - sieveHeight - padding, sieveTop + padding);
确保删除对setXScale()
和setYScale()
的任何其他虚假调用。