BrainFlow
Що таке BrainFlow?
BrainFlow - це розширення BrainF ** k (BFk) з 3 додатковими командами для додаткової функціональності та плутанини.
Які команди?
Крім звичайних команд BFk , ми також маємо:
^ Перехід до комірки № залежно від значення в комірці. Наприклад: Якщо ми знаходимось у комірці № 0 зі значенням 4, ^ перейде нас до комірки №4.
= Встановлює значення в комірці до індексу комірки. Наприклад: Якщо ми знаходимось у комірці №4 зі значенням 0, = встановимо наше значення 4.
& Буде встановлено значення для поточної комірки, рівне значенню в комірці, виходячи зі значення в нашій поточній комірці. (Це важко сказати, тому ось приклад!) Наприклад: Ми знаходимося в комірці №33, і наше поточне значення в цій комірці - 7, і встановимо наше поточне значення в комірці №33 до будь-якого значення в комірці №7.
Необов’язкові виклики
Виконавши будь-яке з наведених нижче, буде застосовано вказаний бонус до вашої кількості байтів.
Interpreter written in BrainFlow
(Можна інтерпретувати зразок і містить принаймні один змістовний ^ = або &): Оцінка / 3
Interpreter written in BrainF**k:
Оцінка / 2
Doesn't contain any English letters (in either upper or lower case):
Оцінка - 20
Doesn't contain any of the BrainFlow / BFk commands in the interpreter itself:
Оцінка - 50
Приклад
Приклад інтерпретатора Java:
import java.util.Scanner;
public class Interpreter {
private String exp;
private int[] values = new int[256];
private int index = 0;
private Scanner in;
public Interpreter(String exp, Scanner in){
this.exp = exp;
this.in = in;
}
public void run(){
//Reset index and values
for(int i = 0; i < values.length; i++){
values[i] = 0;
}
this.index = 0;
System.out.println("Starting...");
this.process(this.exp, false);
System.out.println("\nDone.");
}
private void process(String str, boolean loop){
boolean running = loop;
do{
for(int i = 0; i < str.length(); i++){
switch(str.charAt(i)){
case '>':increaseIndex();break;
case '<':decreaseIndex();break;
case '+':increaseValue();break;
case '-':decreaseValue();break;
case '[':
String s = str.substring(i);
int j = this.getClosingIndex(s);
if(this.values[this.index] == 0){
i +=j;
break;
}
process(s.substring(1, j), true);
i += j;
break;
case '.':
int v = this.values[this.index];
System.out.print((char)v);
break;
case ',':this.values[this.index] = this.in.next().charAt(0);break;
case '^':this.index = this.values[this.index];break;// Jumps to the index specified in the current cell.
case '=':this.values[index] = this.index;break;// Sets the value at cell #x to x
case '&':this.values[index] = this.values[this.values[index]];break;// If cell contains X, makes value of current cell equal to value in cell X
default:
//Ignore others
break;
}
}
if(this.values[this.index] == 0){
running = false;
}
}while(running);
}
private void increaseIndex(){
if(++this.index >= this.values.length){
this.index = 0;
}
}
private void decreaseIndex(){
if(--this.index < 0){
this.index = this.values.length - 1;
}
}
private void increaseValue(){
int newVal = this.values[this.index] + 1;
if(newVal >= this.values.length){
newVal = 0;
}
this.values[this.index] = newVal;
}
private void decreaseValue(){
int newVal = this.values[this.index] - 1;
if(newVal < 0){
newVal = this.values.length - 1;
}
this.values[this.index] = newVal;
}
private int getClosingIndex(String str){
int openings = 0;
int closings = 0;
for(int i = 0; i < str.length(); i++){
char c = str.charAt(i);
if(c == '['){
openings++;
}else if(c == ']'){
closings++;
}
if(openings == closings){
return i;
}
}
return -1;
}
}
Навіть близько до гольфу, але має забезпечити хорошу вихідну точку.
Виграє найнижчий підсумковий результат, де бал - кількість байтів у вашій програмі після врахування відповідних скорочень викликів.
Тестування
Наступна програма BrainFlow повинна надрукувати вказаний вихід після зчитування знака "+" зі стину:
<<,++++[>++++[>++++<-]<-] Set cell #0 to a value dependent on input
>>>+[[-]&>=]+& Set every other cell to that value
[ Start loop
+^ Add one to current value and jump to that cell index
. Print the value at that cell
& Copy value from specified cell
] End loop
Вихід:
ðñðòñðòðôóòñóñôóðòõóñõðôôóòñööõôöðóöðõðùõñô÷ùõóñöóùñô÷øôøõôòöõóðòöóñ÷ðõôûôòú÷úø÷öùøöùñøðùúðûðþöûñùýøðòñ
subset
на extension
. Дякуємо за відгук.
++&
щоб отримати свій вік або+++&
отримати місяць, у якому я народився. звичайно 64-й осередок знаходиться за замовчуванням 0)