Bootstrap
  C.R.T. .com
It doesn't have to be difficult if someone just explains it right.

Welcome to ChineseRemainderTheorem.com!

×

Modal Header

Some text in the Modal Body

Some other text...

Use the calculator below to get a step-by-step calculation of the Chinese Remainder Theory. Just enter the numbers you would like and press "Calculate" .


This removes all numbers from the textboxes, such that you can fill in your own.

This fills all textboxes with random numbers. If you fill in random numbers yourself, it is very likely that those numbers do not have a solution. To avoid disappointment, use this button instead! It only uses random numbers that do have a solution.

This button is similar to the "Clear everything" button, but only clears the left column.
This is useful if you want your equations to be of the form x ≡ a (mod m) rather than bx ≡ a (mod m).
In that case, it can be especially useful after using the random numbers button.

Do you want to use more equations? Go ahead and use this button. It adds another row that you can fill in. Not sure what numbers to put in this newly added row? Use the random numbers button again!

Do you have too many rows? Use one of these buttons to remove a row. You can always add a row again using the yellow "Add a row" button.

Are you ready to view a full step-by-step Chinese Remainder Theorem calculation for the numbers you have entered? Then use this button!

Want to know more?


Transform the equations

You used one or more of the fields on the left, so your equations are of the form bx ≡ a mod m.
We want them to be of the form x ≡ a mod m, so we need to move the values on the left to the right side of the equation.
For a more detailed explanation about how this works, see this part of our page about how to execute the Chinese Remainder algorithm.

First, we calculate the inverses of the leftmost value on each row:

nbqr t1t2t3
86927335001-3
273505231-316
502324-316-35
2345316-35191
4311-35191-226
3130191-226869
So our multiplicative inverse is -226 mod 869 ≡ 643
Source: ExtendedEuclideanAlgorithm.com

nbqr t1t2t3
3113061501-1
30656111-162
5150-162-311
So our multiplicative inverse is 62 mod 311 ≡ 62
Source: ExtendedEuclideanAlgorithm.com

nbqr t1t2t3
521140310101-3
1401011391-34
10139223-34-11
39231164-1115
231617-1115-26
1672215-2667
7231-2667-227
212067-227521
So our multiplicative inverse is -227 mod 521 ≡ 294
Source: ExtendedEuclideanAlgorithm.com

Click on any row to reveal a more detailed calculation of each multiplicative inverse.

Now that we now the inverses, let's move the leftmost value on each row to the right of the equation:

x ≡ 803 × 273-1 (mod 869) ≡ 803 × 643 (mod 869) ≡ 143 (mod 869)
x ≡ 126 × 306-1 (mod 311) ≡ 126 × 62 (mod 311) ≡ 37 (mod 311)
x ≡ 17 × 140-1 (mod 521) ≡ 17 × 294 (mod 521) ≡ 309 (mod 521)


Now the actual calculation

  1. Find the common modulus M
    M = m1 × m2 × ... × mk = 869 × 311 × 521 = 140804939
  2. We calculate the numbers M1 to M3
    M1=M/m1=140804939/869=162031,   M2=M/m2=140804939/311=452749,   M3=M/m3=140804939/521=270259
  3. We now calculate the modular multiplicative inverses M1-1 to M3-1
    Have a look at the page that explains how to calculate modular multiplicative inverse.
    Using, for example, the Extended Euclidean Algorithm, we will find that:

    nbqr t1t2t3
    8691620310869010
    162031869186397101
    86939727501-2
    397755221-211
    752239-211-35
    2292411-3581
    9421-3581-197
    414081-197869
    So our multiplicative inverse is -197 mod 869 ≡ 672
    Source: ExtendedEuclideanAlgorithm.com

    nbqr t1t2t3
    3114527490311010
    4527493111455244101
    31124416701-1
    244673431-14
    6743124-14-5
    43241194-59
    241915-59-14
    195349-1451
    5411-1451-65
    414051-65311
    So our multiplicative inverse is -65 mod 311 ≡ 246
    Source: ExtendedEuclideanAlgorithm.com

    nbqr t1t2t3
    5212702590521010
    270259521518381101
    521381114001-1
    38114021011-13
    140101139-13-4
    101392233-411
    3923116-411-15
    23161711-1526
    16722-1526-67
    723126-67227
    2120-67227-521
    So our multiplicative inverse is 227 mod 521 ≡ 227
    Source: ExtendedEuclideanAlgorithm.com
  4. Now we can calculate x with the equation we saw earlier
    x = (a1 × M1 × M1-1   +   a2 × M2 × M2-1   + ... +   ak × Mk × Mk-1)   mod M
    =  (143 × 162031 × 672 +
       37 × 452749 × 246 +
       309 × 270259 × 227)   mod 140804939
    = 67676125 (mod 140804939)


    So our answer is 67676125 (mod 140804939).


Verification

So we found that x ≡ 67676125
If this is correct, then the following statements (i.e. the original equations) are true:
273x (mod 869) ≡ 803 (mod 869)
306x (mod 311) ≡ 126 (mod 311)
140x (mod 521) ≡ 17 (mod 521)

Let's see whether that's indeed the case if we use x ≡ 67676125.