Questions tagged [brainfuck]

Brainfuck (bf) is an esoteric, Turing-complete programming language famous for its minimalistic, eight-character syntax.

Brainfuck is an esoteric and turing complete programming language famous for its minimalistic eight character syntax.

Brainfuck uses a simple machine model consisting of the program and instruction pointer, and an array of at least 30,000 byte cells initialized to zero. There is a movable data pointer (initialized to point to the leftmost byte of the array), and two streams of bytes for input and output (most often connected to a keyboard and a monitor respectively, and using the ASCII character encoding).

Language syntax

There are 8 language commands, each represented with a single character:

  • > - increment the data pointer (to point to the next cell to the right)
  • < - decrement the data pointer (to point to the next cell to the left)
  • + - increment (increase by one) the byte at the data pointer
  • - - decrement (decrease by one) the byte at the data pointer
  • . - output a character, the ASCII value of which being the byte at the data pointer
  • , - accept one byte of input, storing its value in the byte at the data pointer
  • [ - if the byte at the data pointer is zero, then instead of moving the instruction pointer forward to the next command, jump it forward to the command after the matching ] command
  • ] - if the byte at the data pointer is nonzero, then instead of moving the instruction pointer forward to the next command, jump it back to the command after the matching [ command.

All other characters in the source code are ignored, and there is therefore no special syntax for comments. Despite its minimalistic approach the language is Turing-complete, meaning that any algorithm can be implemented in Brainfuck.

Language semantics

Brainfuck language pseudocode

>   becomes     ++p;
<   becomes     --p;
+   becomes     ++*p;
-   becomes     --*p;
.   becomes     putchar(*p);
,   becomes     *p = getchar();
[   becomes     while (*p) {
]   becomes     }

Hello world Program

The following represents a program that outputs Hello, world! followed by newline \n:

++++++++++[>+++++++>++++++++++>+++>+<<<<-]
>++.>+.+++++++..+++.>++.<<+++++++++++++++.
>.+++.------.--------.>+.>.

The following represents same code with explanation of how it proceeds:

[ This program prints "Hello World!" and a newline to the screen, its
  length is 106 active command characters. [It is not the shortest.]

  This loop is a "comment loop", a simple way of adding a comment
  to a BF program such that you don't have to worry about any command
  characters. Any ".", ",", "+", "-", "<" and ">" characters are simply
  ignored, the "[" and "]" characters just have to be balanced. This
  loop and the commands it contains are ignored because the current cell
  defaults to a value of 0; the 0 value causes this loop to be skipped.
]
+++++ +++               Set Cell #0 to 8
[
    >++++               Add 4 to Cell #1; this will always set Cell #1 to 4
    [                   as the cell will be cleared by the loop
        >++             Add 2 to Cell #2
        >+++            Add 3 to Cell #3
        >+++            Add 3 to Cell #4
        >+              Add 1 to Cell #5
        <<<<-           Decrement the loop counter in Cell #1
    ]                   Loop till Cell #1 is zero; number of iterations is 4
    >+                  Add 1 to Cell #2
    >+                  Add 1 to Cell #3
    >-                  Subtract 1 from Cell #4
    >>+                 Add 1 to Cell #6
    [<]                 Move back to the first zero cell you find; this will
                        be Cell #1 which was cleared by the previous loop
    <-                  Decrement the loop Counter in Cell #0
]                       Loop till Cell #0 is zero; number of iterations is 8

The result of this is:
Cell No :   0   1   2   3   4   5   6
Contents:   0   0  72 104  88  32   8
Pointer :   ^

>>.                     Cell #2 has value 72 which is 'H'
>---.                   Subtract 3 from Cell #3 to get 101 which is 'e'
+++++++..+++.           Likewise for 'llo' from Cell #3
>>.                     Cell #5 is 32 for the space
<-.                     Subtract 1 from Cell #4 for 87 to give a 'W'
<.                      Cell #3 was set to 'o' from the end of 'Hello'
+++.------.--------.    Cell #3 for 'rl' and 'd'
>>+.                    Add 1 to Cell #5 gives us an exclamation point
>++.                    And finally a newline from Cell #6

This article is based on the one found in Wikipedia.

Read more

204 questions
3
votes
2 answers

How to move the pointer by arbitrary amount in BrainFuck?

For example, if the array is like 0 0 0 0 ... 0 0[n]s o m e d a t a 4 9 9 9 9 9 9 8 3 7 ..., how to move the pointer by n, without changing s o m e d a t a 4 9 9 9 ... after the pointer is moved?
JiminP
  • 2,136
  • 19
  • 26
3
votes
1 answer

Uninitialized, writable data before data segment

I'm writing a simple program that converts brainfuck code into x86_64 assembly. Part of that involves creating a large zero-initialized array at the beginning of the program. Thus, each compiled program starts with the following assembly…
3
votes
2 answers

Pointer position - go to 0 or specific (check if out of bounds)

I am a newbie in brainfuck and just starting to take my first steps. I would like some help figuring out a clever way (even if it is a bit hacky) to see if my pointer is out of bounds, before it goes there. Therefore I would like to be able to see…
Angelos Chalaris
  • 6,611
  • 8
  • 49
  • 75
3
votes
1 answer

My seemingly functional BF interpereter cannot run standard BF programs

This is the code for my interpereter: program=list(raw_input('Program: ')) array = [0 for i in range(100)] pointer=0 prgpointer=0 run = True while run: try: command = program[prgpointer] if command == '>': pointer +=…
T Williams
  • 45
  • 5
3
votes
2 answers

How to get a large integer as input and store it in memory

I know that performing arithmetic on large integers in brainfuck, while perhaps quite tedious at times, is entirely possible. However what I'm wondering about is what the generally acceptd best-practices are for taking in large integers (or even…
Cam
  • 14,930
  • 16
  • 77
  • 128
3
votes
2 answers

What is wrong with my beginner Brainfuck addition program?

I've been working on this programming challenge: http://www.codeabbey.com/index/task_view/summing-up Which basically states: Input data has two values A and B in the single line. Output should have the sum A+B printed into it. Additionally after…
Vale
  • 1,003
  • 1
  • 9
  • 22
3
votes
3 answers

Tokenizing a string into a list of nested arrays with Python

Following this document I'm writing an interpreter for Brainfuck, which in my implementation entails turning a string such as: ',>,<[>[->+>+<<]>>[-<<+>>]<<<-]>>.' into a list of instructions like this: [',', '>', ',', '<', [ '>', [ '-', '>', '+',…
Noi Sek
  • 544
  • 8
  • 22
3
votes
1 answer

How to write a "comment" containing a period (.) in Brainfuck?

Is there any way to do comments in Brainfuck that contain periods ('.')? I know I can use basically every char that is not one of the commands, and it is ignored, but I would like to put a version number in a comment at the top of the file, and that…
3
votes
2 answers

What are the uses of Brainfuck?

Are there any confirmed (Documented by the creators, etc) uses or features of Brainfuck that are specific to itself?
HarryCBurn
  • 755
  • 1
  • 8
  • 17
3
votes
2 answers

Extracting brainfuck code from HTML

So I need to extract some brainfuck code from some HTML and what I have been doing so far isn't working. The HTML looks like this
thaweatherman
  • 1,467
  • 4
  • 20
  • 32
3
votes
2 answers

HTML: Change background color of individual characters in textarea?

I'm making a brainfuck interpreter (brainfuck is a programming language consisting of 8 symbols, those are ,.+-<>[] ) Is there a way to color the background of individual characters in a HTML text area through JavaScript? Let's say my text area…
mort
  • 704
  • 2
  • 9
  • 21
2
votes
3 answers

Advanced Java console input

As a self-practice, I'm making a BF interpreter in Java that does I/O through the console. For the most part it's fine, however, as you might be aware, BF takes input one character at a time, including newlines. This means that as far as I know…
user1003382
  • 49
  • 1
  • 6
2
votes
1 answer

Why is my Hello World Program failing?

So, I handwrote this program in BrainFuck: +++++++++++++++++[>++++>++++>++++>++++>++>+++++>++++>++++>++++>++++<<<<<<<<<<-] >++++.>+.>++++++++..>+++++++++++.>--.>++.>+++++++++++.>++++++++++++++.>++++++++.>. and it displays exactly what I…
Peter Olson
  • 139,199
  • 49
  • 202
  • 242
2
votes
1 answer

How do you use the comma command in Brainfuck?

I've been experimenting with the BF esolang today, as I graduated from hello world to an addition program, (which requires the data take in command), I could not for the life of me figure out how this command works. At first I thought you would use…
WrathOfCon
  • 23
  • 4
2
votes
2 answers

Brainfuck: Why does this happen?

I have this pretty simple program: +[----->+++<]>. +[----->+++<]>. Trying to log two g's however the output is gØ how can i make a newline break the code? operator? Not possible?
bruh5000
  • 74
  • 5