Generalize the three overlapping circles project by letting it draw any number of overlapping circles. The following is the overlapping circles from size 2 to size 7.
data:image/s3,"s3://crabby-images/a9636/a9636e1f5f3012704931baf2d5316708084a0469" alt=""
data:image/s3,"s3://crabby-images/0a207/0a2076abdab14035057a44250851e01cb1d0ae22" alt=""
data:image/s3,"s3://crabby-images/b4c49/b4c49af2f4765a78592c5a7b3afa8e5f13987a61" alt=""
data:image/s3,"s3://crabby-images/6e25f/6e25f324b0f83f01755d37948cb3f29fbc502a04" alt=""
data:image/s3,"s3://crabby-images/6a77b/6a77bfdca0e1f80771514c58823d67959a0e5b57" alt=""
data:image/s3,"s3://crabby-images/7d44b/7d44b640434017adbcf610331e4152ae9a6530cb" alt=""
Solution
import turtle
import math
screen = turtle.Screen()
screen.title('N Overlapping Circles - PythonTurtle.Academy')
screen.setup(1000,1000)
turtle.hideturtle()
turtle.speed(0)
turtle.pensize(2)
def draw_circle(x,y,radius):
turtle.up()
turtle.goto(x,y-radius)
turtle.seth(0)
turtle.down()
turtle.circle(radius,steps=360)
r = 150
n = 3
r2 = r/2/math.sin(math.radians(180/n))
angle = 90
for _ in range(n):
draw_circle(r2*math.cos(math.radians(angle)),
r2*math.sin(math.radians(angle)),
r)
angle += 360/n