Skip to content

Grains

Intro

Calculate the number of grains of wheat on a chessboard given that the number on each square doubles.

There once was a wise servant who saved the life of a prince. The king promised to pay whatever the servant could dream up. Knowing that the king loved chess, the servant told the king he would like to have grains of wheat. One grain on the first square of a chess board, with the number of grains doubling on each successive square.

There are 64 squares on a chessboard (where square 1 has one grain, square 2 has two grains, and so on).

Task

Write code that shows:

  • how many grains were on a given square, and
  • the total number of grains on the chessboard

The Code

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#include "grains.h"
#include <stdint.h>

uint64_t square(uint8_t index) {
  if (index > 64 || index < 1)
    return 0;

  int i = 0;
  uint64_t var = 1;
  for (i = 1; i < index; i++) {
    var *= 2;
  }
  return var;
}

uint64_t total(void) {
  uint64_t var = 0;

  int i = 0;
  for (i = 1; i <= 64; i++) {
    var += square(i);
  }
  return var;
}
1
2
3
4
5
6
7
8
9
#ifndef GRAINS_H
#define GRAINS_H

#include <stdint.h>

uint64_t square(uint8_t index);
uint64_t total(void);

#endif

Last update: February 8, 2021

Comments