1*5971e316Smrg for (int c0 = 0; c0 <= 36; c0 += 1) { 2*5971e316Smrg for (int c1 = -6; c1 < c0 / 14 - 5; c1 += 1) { 3*5971e316Smrg for (int c2 = -((-2 * c1 + 3) / 5) + 9; c2 <= c1 + 12; c2 += 1) 4*5971e316Smrg S6(c0, c1, c2); 5*5971e316Smrg for (int c2 = c1 + 24; c2 <= -2 * c1 + 24; c2 += 1) 6*5971e316Smrg S2(c0, c1, c2); 7*5971e316Smrg for (int c2 = -2 * c1 + 30; c2 <= c1 + 48; c2 += 1) 8*5971e316Smrg S1(c0, c1, c2); 9*5971e316Smrg } 10*5971e316Smrg for (int c1 = c0 / 14 - 5; c1 < 0; c1 += 1) { 11*5971e316Smrg if (c1 >= -3 && 2 * c0 >= 7 * c1 + 42) 12*5971e316Smrg S7(c0, c1, 6); 13*5971e316Smrg for (int c2 = max(c1 - (6 * c0 + 77) / 77 + 13, -((-2 * c1 + 3) / 5) + 9); c2 <= c1 + 12; c2 += 1) 14*5971e316Smrg S6(c0, c1, c2); 15*5971e316Smrg for (int c2 = c1 - (3 * c0 + 14) / 14 + 49; c2 <= c1 + 48; c2 += 1) 16*5971e316Smrg S1(c0, c1, c2); 17*5971e316Smrg } 18*5971e316Smrg S3(c0, 0, 0); 19*5971e316Smrg S10(c0, 0, 0); 20*5971e316Smrg for (int c2 = 1; c2 <= 5; c2 += 1) 21*5971e316Smrg S3(c0, 0, c2); 22*5971e316Smrg for (int c2 = 6; c2 <= 2 * c0 / 21 + 4; c2 += 1) { 23*5971e316Smrg S3(c0, 0, c2); 24*5971e316Smrg S7(c0, 0, c2); 25*5971e316Smrg } 26*5971e316Smrg for (int c2 = max(6, 2 * c0 / 21 + 5); c2 <= -((6 * c0 + 77) / 77) + 12; c2 += 1) 27*5971e316Smrg S3(c0, 0, c2); 28*5971e316Smrg for (int c2 = -((6 * c0 + 77) / 77) + 13; c2 <= 12; c2 += 1) { 29*5971e316Smrg S3(c0, 0, c2); 30*5971e316Smrg S6(c0, 0, c2); 31*5971e316Smrg } 32*5971e316Smrg for (int c2 = 13; c2 <= 24; c2 += 1) 33*5971e316Smrg S3(c0, 0, c2); 34*5971e316Smrg for (int c2 = -((3 * c0 + 14) / 14) + 49; c2 <= 48; c2 += 1) 35*5971e316Smrg S1(c0, 0, c2); 36*5971e316Smrg for (int c1 = 1; c1 <= 18; c1 += 1) { 37*5971e316Smrg for (int c2 = -8 * c1; c2 <= min(6, -8 * c1 + 24); c2 += 1) 38*5971e316Smrg S3(c0, c1, c2); 39*5971e316Smrg if (c0 <= 34 && c1 == 1) { 40*5971e316Smrg S3(c0, 1, 7); 41*5971e316Smrg } else if (c1 == 2) { 42*5971e316Smrg S3(c0, 2, 7); 43*5971e316Smrg } else if (c0 >= 35 && c1 == 1) { 44*5971e316Smrg S3(c0, 1, 7); 45*5971e316Smrg S7(c0, 1, 7); 46*5971e316Smrg } 47*5971e316Smrg for (int c2 = 8; c2 <= min(-8 * c1 + 24, c1 - (6 * c0 + 77) / 77 + 12); c2 += 1) 48*5971e316Smrg S3(c0, c1, c2); 49*5971e316Smrg if (c1 == 1) { 50*5971e316Smrg for (int c2 = -((6 * c0 + 77) / 77) + 14; c2 <= 13; c2 += 1) { 51*5971e316Smrg S3(c0, 1, c2); 52*5971e316Smrg S6(c0, 1, c2); 53*5971e316Smrg } 54*5971e316Smrg for (int c2 = 14; c2 <= 16; c2 += 1) 55*5971e316Smrg S3(c0, 1, c2); 56*5971e316Smrg } 57*5971e316Smrg for (int c2 = max(-8 * c1 + 25, c1 - (6 * c0 + 77) / 77 + 13); c2 <= c1 + 12; c2 += 1) 58*5971e316Smrg S6(c0, c1, c2); 59*5971e316Smrg for (int c2 = c1 - (3 * c0 + 14) / 14 + 49; c2 <= c1 + 48; c2 += 1) 60*5971e316Smrg S1(c0, c1, c2); 61*5971e316Smrg } 62*5971e316Smrg for (int c1 = 19; c1 <= 24; c1 += 1) { 63*5971e316Smrg for (int c2 = -8 * c1; c2 <= -8 * c1 + 24; c2 += 1) 64*5971e316Smrg S3(c0, c1, c2); 65*5971e316Smrg for (int c2 = c1 - (6 * c0 + 77) / 77 + 13; c2 <= 30; c2 += 1) 66*5971e316Smrg S6(c0, c1, c2); 67*5971e316Smrg } 68*5971e316Smrg } 69*5971e316Smrg for (int c0 = 37; c0 <= 218; c0 += 1) { 70*5971e316Smrg for (int c1 = (c0 + 5) / 14 - 8; c1 < min(0, c0 / 14 - 5); c1 += 1) { 71*5971e316Smrg if (c0 <= 46 && c1 == -3) 72*5971e316Smrg S7(c0, -3, 6); 73*5971e316Smrg if (77 * c1 + 77 * ((-2 * c1 - 2) / 5) + 524 >= 6 * c0) 74*5971e316Smrg S6(c0, c1, -((-2 * c1 + 3) / 5) + 9); 75*5971e316Smrg for (int c2 = c1 + 24; c2 <= -2 * c1 + 24; c2 += 1) 76*5971e316Smrg S2(c0, c1, c2); 77*5971e316Smrg for (int c2 = -2 * c1 + 30; c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1) 78*5971e316Smrg S1(c0, c1, c2); 79*5971e316Smrg } 80*5971e316Smrg if (c0 <= 148) 81*5971e316Smrg for (int c1 = max(0, (c0 + 5) / 14 - 8); c1 < c0 / 14 - 5; c1 += 1) { 82*5971e316Smrg if (c1 == 0) 83*5971e316Smrg S2(c0, 0, 24); 84*5971e316Smrg for (int c2 = max(c1 + 24, -2 * c1 + 30); c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1) 85*5971e316Smrg S1(c0, c1, c2); 86*5971e316Smrg } 87*5971e316Smrg if (c0 >= 70 && c0 % 14 >= 9) 88*5971e316Smrg for (int c2 = max((c0 + 5) / 14 + 18, -((3 * c0 + 14) / 14) + c0 / 14 + 44); c2 <= -((3 * c0 + 17) / 14) + c0 / 14 + 51; c2 += 1) 89*5971e316Smrg S1(c0, c0 / 14 - 5, c2); 90*5971e316Smrg for (int c1 = c0 / 14 - 5; c1 < 0; c1 += 1) { 91*5971e316Smrg if (7 * c1 + 114 >= 2 * c0) 92*5971e316Smrg S7(c0, c1, 6); 93*5971e316Smrg for (int c2 = max(8, c1 - (6 * c0 + 77) / 77 + 13); c2 <= c1 - (6 * c0 + 91) / 77 + 15; c2 += 1) 94*5971e316Smrg S6(c0, c1, c2); 95*5971e316Smrg for (int c2 = c1 - (3 * c0 + 14) / 14 + 49; c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1) 96*5971e316Smrg S1(c0, c1, c2); 97*5971e316Smrg } 98*5971e316Smrg for (int c1 = max(0, (c0 + 5) / 14 - 5); c1 < c0 / 14 - 2; c1 += 1) { 99*5971e316Smrg for (int c2 = max(c1, -2 * c1 + 6); c2 <= min(c1 + 5, -2 * c1 + 24); c2 += 1) 100*5971e316Smrg S9(c0, c1, c2); 101*5971e316Smrg for (int c2 = c1 + 6; c2 <= min((2 * c1 + 1) / 5 + 7, (2 * c0 - 7 * c1 - 10) / 21 + 1); c2 += 1) 102*5971e316Smrg S9(c0, c1, c2); 103*5971e316Smrg for (int c2 = max(c1 + 6, (2 * c0 - 7 * c1 - 10) / 21 + 2); c2 <= (2 * c1 + 1) / 5 + 7; c2 += 1) { 104*5971e316Smrg S7(c0, c1, c2); 105*5971e316Smrg S9(c0, c1, c2); 106*5971e316Smrg } 107*5971e316Smrg if (c1 <= 3) 108*5971e316Smrg S9(c0, c1, (2 * c1 + 1) / 5 + 8); 109*5971e316Smrg for (int c2 = (2 * c1 + 1) / 5 + 9; c2 <= c1 - (6 * c0 + 91) / 77 + 15; c2 += 1) { 110*5971e316Smrg S6(c0, c1, c2); 111*5971e316Smrg S9(c0, c1, c2); 112*5971e316Smrg } 113*5971e316Smrg for (int c2 = max(max(c1 + 6, c1 - (6 * c0 + 91) / 77 + 16), (2 * c1 + 1) / 5 + 9); c2 <= -2 * c1 + 24; c2 += 1) 114*5971e316Smrg S9(c0, c1, c2); 115*5971e316Smrg for (int c2 = max(c1, -2 * c1 + 30); c2 <= min(c1 + 24, c1 - (3 * c0 + 17) / 14 + 47); c2 += 1) 116*5971e316Smrg S8(c0, c1, c2); 117*5971e316Smrg for (int c2 = max(c1 + 24, c1 - (3 * c0 + 14) / 14 + 49); c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1) 118*5971e316Smrg S1(c0, c1, c2); 119*5971e316Smrg } 120*5971e316Smrg for (int c1 = c0 / 14 - 2; c1 <= 18; c1 += 1) { 121*5971e316Smrg for (int c2 = max(6, (c0 + 5) / 14 + 1); c2 <= min(min(c1, c0 / 14 + 3), -c1 + c1 / 2 + 18); c2 += 1) 122*5971e316Smrg S5(c0, c1, c2); 123*5971e316Smrg for (int c2 = max(c1 + (3 * c0 + 3) / 14 - 40, -c1 + (c1 + 1) / 2 + 21); c2 <= min(c1, c1 + 3 * c0 / 14 - 33); c2 += 1) 124*5971e316Smrg S4(c0, c1, c2); 125*5971e316Smrg for (int c2 = c1 + 6; c2 <= min((2 * c1 + 1) / 5 + 7, (2 * c0 - 7 * c1 + 63) / 21 + 1); c2 += 1) 126*5971e316Smrg S7(c0, c1, c2); 127*5971e316Smrg for (int c2 = max(max(c1 + 6, c1 - (6 * c0 + 77) / 77 + 13), (2 * c1 + 1) / 5 + 9); c2 <= c1 - (6 * c0 + 91) / 77 + 15; c2 += 1) 128*5971e316Smrg S6(c0, c1, c2); 129*5971e316Smrg for (int c2 = max(c1, c1 - (3 * c0 + 14) / 14 + 40); c2 <= min(c1 + 24, c1 - (3 * c0 + 17) / 14 + 47); c2 += 1) 130*5971e316Smrg S8(c0, c1, c2); 131*5971e316Smrg for (int c2 = max(c1 + 24, c1 - (3 * c0 + 14) / 14 + 49); c2 <= c1 - (3 * c0 + 17) / 14 + 56; c2 += 1) 132*5971e316Smrg S1(c0, c1, c2); 133*5971e316Smrg } 134*5971e316Smrg for (int c1 = 19; c1 <= 24; c1 += 1) { 135*5971e316Smrg for (int c2 = max(c1 - 12, (c0 + 5) / 14 + 1); c2 <= min(c0 / 14 + 3, -c1 + c1 / 2 + 18); c2 += 1) 136*5971e316Smrg S5(c0, c1, c2); 137*5971e316Smrg for (int c2 = max(max(c1 - 12, c1 + (3 * c0 + 3) / 14 - 40), -c1 + (c1 + 1) / 2 + 21); c2 <= min(c1, c1 + 3 * c0 / 14 - 33); c2 += 1) 138*5971e316Smrg S4(c0, c1, c2); 139*5971e316Smrg for (int c2 = max(c1 + 6, c1 - (6 * c0 + 77) / 77 + 13); c2 <= min(30, c1 - (6 * c0 + 91) / 77 + 15); c2 += 1) 140*5971e316Smrg S6(c0, c1, c2); 141*5971e316Smrg for (int c2 = max(c1, c1 - (3 * c0 + 14) / 14 + 40); c2 <= min(c1 + 24, c1 - (3 * c0 + 17) / 14 + 47); c2 += 1) 142*5971e316Smrg S8(c0, c1, c2); 143*5971e316Smrg } 144*5971e316Smrg for (int c1 = 25; c1 <= min(42, -((3 * c0 + 17) / 14) + 71); c1 += 1) 145*5971e316Smrg for (int c2 = max(c1 - 12, c1 + (3 * c0 + 3) / 14 - 40); c2 <= min(min(30, c1), c1 + 3 * c0 / 14 - 33); c2 += 1) 146*5971e316Smrg S4(c0, c1, c2); 147*5971e316Smrg } 148