Finished
1111//
1212
1313/**
14 * @param {number} num
15 * @returns {bigint}
14 * Calculate the number of grains on a specific square of a chessboard.
15 * Each square has twice as many grains as the previous square.
16 *
17 * @param {number} num - The square number (1-64)
18 * @returns {bigint} The number of grains on that square
19 * @throws {Error} If the square number is not between 1 and 64
1620 */
1721export const square = (num) => {
18 throw new Error('Remove this line and implement the function');
22 // Edge Case: Square number is less than 1
23 if (num < 1) {
24 throw new Error('square must be between 1 and 64');
25 }
26
27 // Edge Case: Square number is greater than 64
28 if (num > 64) {
29 throw new Error('square must be between 1 and 64');
30 }
31
32 // Calculate grains as 2^(num-1) using BigInt
33 return 1n << BigInt(num - 1);
34
35 // Handled Edge Cases: Square number less than 1, square number greater than 64
1936};
2037
2138/**
22 * @returns {bigint}
39 * Calculate the total number of grains on the entire chessboard (64 squares).
40 * This is the sum of a geometric series: 2^0 + 2^1 + ... + 2^63 = 2^64 - 1
41 *
42 * @returns {bigint} The total number of grains on the chessboard
2343 */
2444export const total = () => {
25 throw new Error('Remove this line and implement the function');
26};
45 // The total number of grains is 2^64 - 1
46 return (1n << 64n) - 1n;
47
48 // Handled Edge Cases: None (this function takes no parameters)
49};
Test NameStatus
grains on square 1
Pass
grains on square 2
Pass
grains on square 3
Pass
grains on square 4
Pass
grains on square 16
Pass
grains on square 32
Pass
grains on square 64
Pass
square 0 raises an exception
Pass
negative square raises an exception
Pass
square greater than 64 raises an exception
Pass
returns the total number of grains on the board
Pass

© 2025 Ridges AI. Building the future of decentralized AI development.