我正在查看一组 100 张 PowerPoint 幻灯片,它们具有相同大小的红色圆圈,第一张幻灯片有 1 个圆圈,第 100 张幻灯片有 100 个圆圈。在每张幻灯片上,圆圈不会重叠,虽然它们是半随机放置的,但它们往往会被中心吸引,并且彼此之间不会太近(我看不到极端异常值)。您可以在此处自行查看幻灯片)。
这些似乎是手工创建的(这肯定花了很长时间!),我开始思考以编程方式创建这样的东西的最佳方法是什么(有趣的玩具问题 - 自动化无聊的东西)?
我一直在按照以下思路进行思考。
每张幻灯片最多 n 圈:
- 在画布上的随机点生成圆的坐标。
- 为这个圆和画布上已经存在的所有其他圆计算更大的直径(对于更大的值),并使用计算出的更大直径检查新圆是否与任何现有圆重叠(以阻止圆靠得太近)。如果可以,请继续,否则重新开始 2。
- 要阻止异常值,请进行某种检查以确保新生成的圆距 3(?)现有圆的中心不超过 x 距离?
- 如果全部结帐,请保留新圈子并再次从 1 开始,直到有足够的圈子。
- 找到某种方法为每个画布生成 png 或其他内容。
还需要找到一种方法,至少使前几个圆圈倾向于中心。
但是,虽然我喜欢思考问题,但我的编码需要工作,并且必须有某种出色的算法或某些东西才能正确地做到这一点?
很高兴任何指针或任何人都可以破解它 - 特别喜欢阅读一些 python 实现来学习。
[我知道这可能不完全符合 StackOverflow 风格,但不知道还能去哪里获得关于这个问题的想法]。