How Many Squares Does the Diagonal Cross ? Edited

A diagonal is drawn on the floor from 1 corner to the opposite corner of a rectangular room covered with square tiles 1' x 1'.

A number of tiles are crossed by the diagonal. This depends on the size of the room and the relation of the width and the length.

Let A = # of tiles crossed in a room 32' x 48',

B = # of tiles crossed in a room 32' x 47',

and C = # of tiles crossed in a room 32' x 46'

Find the sum A + B + C


The answer is 218.

This section requires Javascript.
You are seeing this because something didn't load right. We suggest you, (a) try refreshing the page, (b) enabling javascript if it is disabled on your browser and, finally, (c) loading the non-javascript version of this page . We're sorry about the hassle.

4 solutions

Sharky Kesa
Sep 15, 2014

I have done a question like this before.

For any sized room with side lengths m m and n n , the number of tiles(T) that are crossed from the diagonal can be shown by the formula:

m + n H C F ( m , n ) = T m + n - HCF(m, n) = T

Substituting the values and simplifying, we get

A = 32 + 48 H C F ( 32 , 48 ) A = 32 + 48 - HCF(32, 48)

A = 64 A = 64

B = 32 + 47 H C F ( 32 , 47 ) B = 32 + 47 - HCF(32, 47)

B = 78 B = 78

C = 32 + 46 H C F ( 32 , 46 ) C = 32 + 46 - HCF(32, 46)

C = 76 C = 76

Adding these up, we get

64 + 78 + 76 = 218 64 + 78 + 76 = 218

218 is the answer.

Would you please explain how you got the formula?

Agnishom Chattopadhyay - 6 years, 9 months ago

Log in to reply

I had to solve a question like this and the formula was the solution.

Sharky Kesa - 6 years, 9 months ago

Log in to reply

I'd be very happy to see the solution.

Agnishom Chattopadhyay - 6 years, 9 months ago

Log in to reply

@Agnishom Chattopadhyay Sharky has posted the solution. Look above.

Guiseppi Butel - 6 years, 8 months ago

Log in to reply

@Guiseppi Butel That is not what I mean

Agnishom Chattopadhyay - 6 years, 8 months ago

Log in to reply

@Agnishom Chattopadhyay Formulas are developed by viewing the results for many different parameters and then devising a formula to accommodate all the results.

Guiseppi Butel - 6 years, 8 months ago

Haven't seen this formula before but developed the same method of attack. What started me on this was a problem that had sides 363 and 410. I started thinking about it, wondered about the strange pair of numbers, but later lost the problem and made my own.

Would the answer to the 363, 410 combo be 772?

Guiseppi Butel - 6 years, 9 months ago

Log in to reply

Yeah. 772 would be the answer.

Sharky Kesa - 6 years, 9 months ago
Tim Cieplowski
Sep 21, 2014

In a p × q p \times q rectangle where gcd ( p , q ) \gcd(p,q) = 1, your journey through tiles can be represented as a string of Us and Rs (U means you cross up, R means you cross right). There will be p 1 p-1 Rs and q 1 q-1 Us, to move over p p and up q q so starting with the first tile you pass through 1 + ( p 1 ) + ( q 1 ) = p + q 1 1 + (p-1) + (q-1) = p+q-1 tiles.

m gcd ( m , n ) and n gcd ( m , n ) {m \over \gcd(m,n)} \mbox{ and } {n \over \gcd(m,n)} are relatively prime, so imagine g c d ( m , n ) gcd(m,n) blocks of this size across the diagonal of the room. Each block meets the next at a multiple of ( m gcd ( m , n ) , n gcd ( m , n ) ) \left( {m \over \gcd(m,n)}, {n \over \gcd(m,n)} \right) , a corner of a tile where you move up and right without entering any tile not counted in a path through a block. So there are gcd ( m , n ) ( m gcd ( m , n ) + n gcd ( m , n ) 1 ) = m + n gcd ( m , n ) \gcd(m, n) \left( {m \over \gcd(m,n)} +{n \over \gcd(m,n)}-1 \right) = m + n - \gcd(m, n) tiles crossed by a m × n m \times n path.

Bill Bell
Aug 14, 2015

Interesting as a computational geometry problem. Mind you, this solution is only brute force and could be radically improved upon.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
from itertools import product
from fractions import Fraction

def crossedTiles(size=(6,9)):
    slope=Fraction(size[0],size[1])
    lattice=product(range(1+size[1]),range(1+size[0]))
    above=[]
    below=[]
    for point in lattice:
        if point[1]>Fraction(point[0]*slope):
            above.append(point)
        if point[1]<Fraction(point[0]*slope):
            below.append(point)
    count=0
    for a in above:
        for b in below:
            if a[0]+1==b[0] and a[1]-1==b[1]:
                count+=1
    return count

print crossedTiles((32,48))+crossedTiles((32,47))+crossedTiles((32,46))

Here are some convention I used to solve the problem

I used ! for multiplication, as I was unable to use the star symbol *

[x] - greatest integer >=x

{x} - least integer <=x

Approach: For a square of mXn. I am trying to check how many squares the diagnal crossed for every unit of n.

Lets take the figure 4X6 described in the question m=4, n=6

Assume x axis along the line of 'n'. and Y axis over line m. and bottom left corner to be origin.

For every unit increment in x, y increases by m/n(=4/6)

For x -> 0 to 1 y -> 0 to 4/6

No of squares crossed by diagnal in band x -> 0 to 1 = 1 = {4/6} - [0]

For x -> 1 to 2 y -> 4/6 to 2!4/6

No of squares crossed by diagnal in band x -> 1 to 2 = 2 = {2!4/6} - [4/3]

For x -> 2 to 3 y -> 2!4/6 to 3!4/6

No of squares crossed by diagnal in band x -> 2 to 3 = 1 = {3!4/6} - [2!4/3] ...

Generalizing for mXn square

b=m/n

no of squares crossed in band n from a to a+1 , a is integer and a<n-1 == {(a+1)b}-[ab]

So total no of squares crossed = ({b}+{2b}+....+{nb}) - ([b]+[2b]+....+[(n-1)b])

Now for 32X48 m=32, n=48,b=32/48

No of squares crossed = ({32/48}+{2!32/48}+...+{48!32/48}) - ([32/48]+[2!32/48]+....+[47!32/48]) = (1+2+2+3+4+4+.....+31+32+32) (0+1+2+2+3+4+4+.....+30+30+31) =64

You can find the pattern above, all the even numbers are repeated twice wheareas all the odd numbers occur only once

Similarly you can find such pattern for 32X46 and 32X47 and solve them to be 76 and 78 respectively

So the answer is 64+76+78 = 218

Please let me know if my presentation is not good enough to convey my thoughts....

0 pending reports

×

Problem Loading...

Note Loading...

Set Loading...