Texto a Brain-Flak


13

Su desafío es convertir el texto de entrada en código de rechazo mental que generará el texto.

Tutorial tomado de aquí con permiso aquí

Brain-Flak tiene dos pilas, conocidas como 'izquierda' y 'derecha'. La pila activa comienza a la izquierda. Si aparece una pila vacía, devolverá 0. Eso es todo. No hay otras variables. Cuando se inicia el programa, cada argumento de línea de comando se transfiere a la pila activa.

Los únicos caracteres válidos en un programa Brain-Flak son ()[]{}<>, y siempre deben estar equilibrados. Hay dos tipos de funciones: Nilads y Mónadas . Un nilad es una función que toma 0 argumentos. Aquí están todas las nilas:

  • () Evalúa a uno.
  • [] Evalúa a la altura de la pila actual.
  • {}Pop la pila activa. Evalúa el valor reventado.
  • <>Alternar la pila activa. Evalúa a cero.

Estos se concatenan juntos cuando se evalúan. Entonces, si tuviéramos un '3' en la parte superior de la pila activa, este fragmento:

()(){}

evaluaría a 1 + 1 + active.pop()cuál evaluaría a 5.

Las mónadas toman un argumento, un trozo de código Brain-Flak. Aquí están todas las mónadas:

  • (n) Empuje 'n' en la pila activa.
  • [n] Evalúa a negativo 'n'
  • {foo} Mientras que cero no está en la parte superior de la pila, haz foo.
  • <foo> Ejecute foo, pero evalúelo como 0.

Estas funciones también devolverán el valor dentro de ellas, por lo que

(()()())

Empujará 3 pero

((()()()))

Empujará 3 dos veces .

El {}evaluará a la suma de todas las corridas. Entonces, si tuviéramos '3' y '4' en la parte superior de la pila:

{{}}

evaluaría como 7.

Cuando el programa termina de ejecutarse, se imprime cada valor que queda en la pila activa, con una nueva línea entre ellos. Los valores en la otra pila se ignoran.

Reglas

  • Puede suponer que el Brain-Flak se está ejecutando sin ascii. ( -A)
  • El código brain-flak NO debe requerir entrada
  • Se aplican todas las reglas estándar.
  • El código debe ejecutarse en 1 minuto para cualquier entrada de hasta 1024 bytes en TIO. (Si no hay salida TIO disponible, proporcione un intérprete y lo ejecutaré en mi máquina (mi máquina debería poder acercarse a TIO)).
  • Debe admitir entradas de longitud arbitrarias.
  • Puede tomar la entrada de un archivo.
  • La optimización para casos de prueba no está permitida
  • Se requiere salida determinista
  • Los programas no necesitan estar limpios

Casos de prueba (pruebe su código en estos, los textos de puntuación reales se publicarán en 1-2 semanas después de que se publique el desafío)

ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz

The meaning of brain-flak is to flak your brain with pain.

`1234567890-=qwertyuiop[]\asdfghjkl;'zxcvbnm,./~!@#$%^&*()_+QWERTYUIOP{}|ASDFGHJKL:"ZXCVBNM<>?

To be, or not to be, that is the question:
Whether 'tis nobler in the mind to suffer
The slings and arrows of outrageous fortune,
Or to take arms against a sea of troubles
And by opposing end them. To die-to sleep,
No more; and by a sleep to say we die

<your brain-flak code here>

The fitness pacer test is a multi stage test. Avacado Avacado Avacadad Avacadad carrot.bat carrot.jar carrot.carrot Quack Quack Quack Quack Quack Quack Quack Quack Quack downgoat doawngoat down down gaot



This challenge came from a online program that turned text into brain-fuck. However brain-fuck has limitations and it is not nearly as cool as brain-flak. I really am looking forward to cool programs :) I am glad you took the time to read this and look forward to seeing your answer.

Victorioso

Para ganar, debe proporcionar la longitud total del código de bloqueo cerebral proporcionado por cada uno de los casos de prueba que se publicarán 1-2 semanas después de la fecha de publicación. La longitud total más corta gana.

¡¡¡¡¡¡NOTA!!!!!!:

Esto no es , la longitud de su código no afectará su puntaje final de ninguna manera. Se agradece hacer un código legible limpio. ¡Gracias!

Casos de prueba

aquí



44
Los memes de TNB son los memes más húmedos.
Urna mágica de pulpo

1
Ojalá pudiera doblar +1 esto, en cambio ofreceré una recompensa porque quiero saber cómo se supone que debe hacerse. La primera respuesta que se pone por <your brain-flak code here>debajo de 1000 recibe la recompensa. Que no puedo publicar para otro día, whoops; no me di cuenta de lo nuevo que era esto.
Urna mágica de pulpo

1
Además, si el rango de entrada no se limita a ASCII imprimible, debe incluir casos de prueba que tengan todos los valores de bytes, incluidos los bytes NUL.
mbomb007

2
"Hacer un código limpio y legible es apreciado" apresuradamente desafía en 05AB1E
Magic Octopus Urn

Respuestas:


13

Brain-Flak , 130 bytes

{({}<>)<>}<>{((((()()()()()){}){}){}<>)<>{(((((()()()()()){}){}){}<>)())<>({}[()])}<>((((()()()()()){}){}){}())<>{}}<>{({}<>)<>}<>

Pruébalo en línea!

Salida para <your brain-flak code here>: 5045 bytes

(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())(()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())

Pruébalo en línea!


1
Se agudiza el
Urna de pulpo mágico

1
@MagicOctopusUrn metaflakking : D
HyperNeutrino

Los casos de prueba están fuera
Christopher

7

Python 3 , 17744 bytes

Editar: he agregado un par de opciones para ayudar al golf en situaciones seguras.

import sys
sys.setrecursionlimit(1000000)
import time

def copy(n, code):
	if n == 1: return code
	for x in range(2, n):
		if n%x == 0: return '('*(x-1) + copy(n//x, code) + ')'*(x-1) + '{}'*(x-1)
	return '('*(n-1) + code + ')'*(n-1) + '{}'*(n-1)

letterCache = {}
def letterGen(n, stackLen, prev=0, enclosed=0):
	if (n, stackLen, prev, enclosed) in letterCache: return letterCache[(n, stackLen, prev, enclosed)]
	if n == 0: return ''
	if n == 1: return '()'
	if n == stackLen: return '[]'
	f = []
	if n < 0:
		f.append('[%s]'%letterGen(-n, stackLen, prev, enclosed))
	else:
		if prev != 0:
			diff = n-prev
			#Saves ~200 bytes but 20x longer
			#for x in range(min(diff, 0)-stackLen, max(diff, 0)+stackLen+1):
				#f.append(letterGen(x, stackLen - enclosed) + 's' + letterGen(diff - x, stackLen))

			f.append('s' + letterGen(diff, stackLen))
			f.append(letterGen(diff, stackLen - enclosed) + 's')
		x = 2
		while x*x < n:
			f.append(copy(x, letterGen(n//x, stackLen, prev, enclosed)) + letterGen(n%x, stackLen, prev, enclosed))
			x += 1
		f.append(letterGen(n-1, stackLen, prev, enclosed)+'()')
		if abs(n-stackLen) < n and stackLen > 1: f.append(letterGen(n-stackLen, stackLen, prev, enclosed) + '[]')
	letterCache[(n, stackLen, prev, enclosed)] = min(f, key=len)
	return letterCache[(n, stackLen, prev, enclosed)]

def s2BrainFlak(c, checkReverse = True):
	g = []
	c = c[::-1]
	stack = []
	out = []
	enclosed = 0

	if checkReverse:
		g.append(''.join(out) + s2BrainFlak(c, False) + '{({}<>)<>}<>')
		#for x in range(1,11): g.append(s2BrainFlak(list(c)+[chr(0)]*x, False) + '{({}<>)<>}<>')
	#if c and c[0] == chr(0):
	#	out.append('<>')
	#	while c[0] == chr(0):
	#		stack.append(0)
	#		out[0] = '(' + out[0] + ')'
	#		c = c[1:]


	for letter in range(len(c)):
		char = ord(c[letter])
		x = '(%s)'%letterGen(char, len(stack), stack[-1] if stack else 0, enclosed)

		if 's' in x:
			out[-1] = x.replace('s', out[-1])
			enclosed += 1
		else:
			out.append(x)
			enclosed = 1
		if checkReverse and c[letter+1:]:
			g.append(''.join(out) + '<>' + s2BrainFlak(c[letter+1:], False) + '{({}<>)<>}<>')
			m = min(list(map(ord, c[letter+1:])))-1
			#for i in range(1,m): g.append(''.join(out) + '<>' + s2BrainFlak(list(map(lambda x: chr(ord(x)-i), c[letter+1:])), False) + "{({}%s<>)<>}<>"%letterGen(i, 0))
			g.append(''.join(out) + '<>' + s2BrainFlak(list(map(lambda x: chr(ord(x)-m), c[letter+1:])), False) + "{({}%s<>)<>}<>"%letterGen(m, 0))
			#for x in range(1,11): g.append(''.join(out) + s2BrainFlak(list(c)+[chr(0)]*x, False) + '{({}<>)<>}<>')
		stack.append(char)
	g.append(''.join(out))
	return min(g, key=len)

Pruébalo en línea!

Una solución recursiva simple que continuaré mejorando aún más. Esto hace muy bien con entradas más pequeñas, pero pierde la respuesta Ruby de MegaTom para entradas más largas.

Notas:

  • Esto necesita una pila limpia para operar; de lo contrario, las mejoras se []volverán inútiles (aunque pueden desactivarse comentando un par de líneas, y solo lo mejoran al aproximadamente 100 bytes) bastante).
  • Dado que este es un algoritmo recursivo, tomará más tiempo para los caracteres con valores grandes. Por ejemplo, el carácter ÿ (valor 255) tarda 9 segundos en evaluarse, donde cada caso de prueba a la vez tarda 1,6 segundos. Caché implementado!
  • La idea de verificar el reverso tomó descaradamente la respuesta de HyperNeutrino , ahorrando 800 bytes del total.
  • Cambié el total de todos los casos de prueba a la vez al total de cada caso de prueba. Esto ahorra algunos bytes al agregar más usos para el operador de longitud de pila ( [])
  • ~ 200 bytes desde elegir el mínimo de anteponer la diferencia entre caracteres, o agregarlos (nuevamente, esto ahorra bytes a través del operador de longitud de pila)
  • Implementé un caché (que almacena valores en función de la longitud de la pila), lo que me permitió verificar más posibles vías sin exceder el límite de tiempo. Esto ahorró 1500 bytes del total.
    • Además, cambié el tablero de em en el caso de prueba de Shakespeare a un normal -. Esto recortó algunos bytes, y mucho tiempo dado el valor de ese guión em fue 8212: o.
  • Recorte 1200 bytes de los casos de prueba más largos cortándolos en rodajas y verificando si era más corto cambiar a la otra pila, construirlo en reversa y empujarlo nuevamente a la primera pila. A continuación, aún más corte y ahorro de tiempo al optimizar el rango mínimo de corte.
  • Combinó la función de generación de números con la comprobación de eficiencias con la parte de carácter anterior en una función recursiva. Hay un par de secciones aquí que guardan algunos bytes, pero extienden el tiempo de ejecución del programa un poco más allá del límite de un minuto.
    • Descomentar esas partes puede reducirlo a 11394 bytes ... pero lleva unos 16 minutos.

Salidas de ejemplo:

<your brain-flak code here> (312 bytes):

(()(((((((((()()()){}()){}()){}){})){}())[(()[][]){}])[][])[[]])([]((((([]((()[][][]){})[][]){})(()[]){})[()[][]])[()][]))([()][]([[]]((((([][]){}())){}[])(()()()){})))([()()()][]((((((()()[[][]]([()()()()][]((([][])[]){}()))[])())[((()()[])){}{}])[()()][]){})[()()()]))(([][]){}())((()()()()()[]){}){({}<>)<>}<>

Pruébalo en línea!

Hello, World!( 142 bytes [Nota: el mejor anterior actual era 148 bytes , y ahora es de 136 bytes]):

((()(((((((((()()()()){}){}){}()))){}{}())([][]){})[][])[[]])[((()[]){}){}])([()[]](((()(()[]([][]((()[][]){}[]))){}[])[()()()])))(([][][]){})

Pruébalo en línea!


¿comprobar la reversión ahorra 800 bytes? o_O
HyperNeutrino

También debe almacenar en caché los resultados de su función recursiva; ahorraría mucho tiempo
HyperNeutrino

@HyperNeutrino Caching significa que no puedo usar el operador de longitud de pila, que en realidad ahorra mucho, especialmente para entradas más cortas
Jo King

1
@HyperNeutrino Me acabo de dar cuenta de que puedo tener un caché, siempre y cuando haga cachés separados para cada altura de pila
Jo King

1
¿Tu meta-golfista de brain-flak superó la mejor respuesta para un golf regular de brain-flak? Qué.
Urna de pulpo mágico

5

Ruby , 17398 bytes para todos los casos de prueba (nuevos)

# cache for holding shortest push results
$p_cache = {} 

# Get code to push a number "a" to the stack,
#  given top of stack "b" and stack height "h"
def push a,b=nil,h=0
  return $p_cache[[a,b,h]] if $p_cache[[a,b,h]]
  arr = []
  if b
    arr.push "(({})#{add(a-b,h)})"
  end
  arr.push "(#{add a,h}  )"
  arr.push "([]#{add a-h,h}  )"
  i=2
  while i*i<=a && i<4
    arr.push "#{'('*(i-1)}#{push a/i,b,h}#{')'*(i-2)+'{}'*(i-1)}#{add(a%i,h)})"
    i+=1
  end
  $p_cache[[a,b,h]] = arr.min_by(&:length)
end


$cache = {}

# Get code to add a number "n" to the 3rd stack
#  given stack height "h" 

def add n,h=0
  return $cache[[n,h]] if $cache[[n,h]]
  arr = []
  if n > 0
    arr.push("()"*n)
  elsif n == 0
    return ""
  else
    if h > 0
      1.upto(-n/h){|i|
        arr.push "[#{'[]'*i}]#{add(h*i+n,h)}"
      }
    end
    arr.push "[#{add(-n,h)}]"
    return ($cache[[n,h]] = arr.min_by &:length)
  end
  
  if h > 0
    if n > h
      arr.push "[]#{add n-h,h}"
    else
      arr.push "[]#{add n-h}"
    end
  end
  
  i=2
  while i*i<=n && i<4
    arr.push "#{'('*(i-1)}#{add n/i,h}#{')'*(i-1)+'{}'*(i-1)}#{add(n%i,h)}"
    x=n-h-i+1
    if x > 0
      arr.push "#{'('*(i-1)}#{add x/i,h}#{')'*(i-1)}[]#{'{}'*(i-1)}#{add(x%i)}"
    end
    i+=1
  end
  $cache[[n,h]] = arr.min_by &:length
end

def push_arr(arr)
  i=0
  code = push(arr[0]) + "\n" + 
  arr.each_cons(2).map{|r|
    i+=1;push r[1],r[0],i
  }.join(?\n)
  
  while code =~ /^\((.*)\)\n(\(*)\{\}/
    code.gsub!(/^\((.*)\)\n(\(*)\{\}/, '\2\1')
  end
  
  code.split(/\n| /).join
end

# push a string to the stack
def push_string(text)
  push_arr text.chars.map(&:ord)
end

$str_cache = {}
# Push a string in reverse order
def push_string_r(text)
  return $str_cache[text] if $str_cache[text]
  a = [push_string(text)+"{({}<>)<>}<>", push_string(text.reverse)]
  
  min = text.bytes.min-1
  a.push push_arr(text.bytes.map{|x|x-min}) + "{({}<>#{add min})<>}<>"

  # Try cutting it into bits
  3.upto([text.length/20, 10].min)do|x|
    spl = x*9
    a.push push_string_r(text[spl..-1]) + "<>" + 
      push_string(text[0...spl]) + "{({}<>)<>}<>"
    spl = x*10
    a.push push_string_r(text[spl..-1]) + "<>" + 
      push_string(text[0...spl]) + "{({}<>)<>}<>"
  end
  
  a.map!{|code|code.gsub("<><>","")}

  $str_cache[text] = a.min_by &:length
end

Pruébalo en línea!


<your brain-flak code here>, 362 358 bytes

((((((((((()()()){}()){}()){}){})){}())[[][][][][]])[][])[()()()])((((((((([][][]()){}))){}{}()())[][]()())[[][]()])[][()])()()()()())([][][][]())(((([]([]())[]{}){})(()()()){})[[][()()()]])([]([][][]()){})((([][])[]){}())([]([][]())[]{})((([][]()())[]{})())((((((()()()()())[]{})[][()()]){})[()()()])((()()()){}){}())([][][][]())(((()())[]{}){}){({}<>)<>}<>

Pruébalo en línea!


Su código toma más de 1 minuto para todos los casos de prueba a la vez (~ 950 bytes). Sin embargo, es bueno que produzca un código bastante corto para los casos de prueba individuales más largos.
Jo King

@JoKing está bien que tome más tiempo para cada caso: P
Christopher

@ Christopher Me refería a la Must run under 1 minute for inputs up to 1024 bytesregla (aunque ahora es mucho más rápido)
Jo King

1
Aunque en realidad no importa para la ejecución del código, un objeto que almacena datos para su uso posterior se llama a cache, no cash; p
Value Ink

Los casos de prueba están fuera
Christopher

4

Python 3 , 16222 bytes

cache = {}

def generate_number(num, height, level = 0, output = False): # Idea to use Stack Height inspired by Jo King
	if output: print(" " * level + str(num) + " " + str(height))
	if (num, height) in cache: return cache[(num, height)]
	if num == 0: return ""
	if num < 0: return "[" + generate_number(-num, height, level + 1, output) + "]"
	if num == height: return "[]"
	value = min((["[]" + generate_number(num - height, height, level + 1, output)] if height > num * 2 and abs(num - height) < num else []) + ["()" + generate_number(num - 1, height, level + 1, output)] + ["(%s)%s{}" % (generate_number(num // i, height, level + 1, output), "({})" * (i - 2)) for i in range(2, num) if num % i == 0], key = len)
	cache[(num, height)] = value
	return value

generate_number(256, 0, 0, False)

def generate_string(array):
	string = ""
	last = 0
	for height, num in enumerate(array):
		string = min("(" + string + generate_number(num - last, height) + ")", "<" + string + ">" + "(" + generate_number(num, height) + ")", key = len)
		last = num
	return string

a = lambda s: generate_string(list(map(ord, s)))

i = sys.stdin.read()
j = i[::-1]

print(min(a(j), a(i) + "{({}<>)<>}<>", key = len))

Pruébalo en línea!

Primero debajo de 1000 para <your brain-flak code here>: D

Brain-Flak , 448 bytes

<((((((<(((<((((<((((<((((((()(()(()(()()()){}){}){}){})(()((()()[]){}){})({}){})()((()[]){}){})[()(([]){}){}])()()())>((()([])({}){}){})()((()(()()[]){}){}){})[()])()()()[])[()()()[]])>(()()([])({}){})(()(()[]){})({}){})[(()()()()()){}])()(()()()()()){})[(()()()){}])>(([])({}){})()(([]){}){})[()()()()()])[(()()()()){}])>((([])({}){}){})[((()()()()){}){}])[(()[])({}){}])()(()()()()()[])({}){})()()())[(()()()){}])(()()()()()){})>((()()()()[]){})

Pruébalo en línea!

(originalmente 827 para <your brain-flak code here>)


Bounty inc, pronto.
Urna de pulpo mágico

@MagicOctopusUrn cool ty: D
HyperNeutrino

Ahora tiene un total de 16222 bytes
Jo King

Hope 250 fue genial.
Urna de pulpo mágico

@MagicOctopusUrn 250 es genial: D tyvm
HyperNeutrino

3

05AB1E , demasiados bytes (mi primer BF cualquier cosa)

ÇεDÑDg;<èUX÷VX"()"×"(ÿ)"YX-"()"׫"(ÿ)"}»"{({}<>)({<({}[()])><>({})<>}{}<><{}><>)<>}<>"«

Pruébalo en línea!


Intento extremadamente básico de golf usando el código de "multiplicación" prefabricado Brain-flak. Todo lo que hace es encontrar el par divisor de suma más pequeña para cada punto de código ASCII, luego empuja ambos pares de divisores como números. El código Brainflak ({}<>)({<({}[()])><>({})<>}{}<><{}>)se agrega y ejecuta en un bucle hasta que todos los valores estén en la pila alternativa.


Lista de personas a las que agradezco:

  • DJMcMayhem para señalar (()())(()()())= ((()())())( -252 bytes)
  • DJMcMayhem por mostrarme cómo deberían funcionar los bucles ( -927 bytes).

Ejemplo de golf <your brain-flak code here>en 3470 3218 2291 bytes:

Brain-Flak , 2291 bytes

((()()()()()())()()()())
((())()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())
((()()())()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())
((()()()()()()()()())()()()())
((()()()()()())()()()()()()()()()()()()())
((()()()())()()()())
((()()()()()()())()()()()()()())
((()()()()()())()()()()()()()()()()()()())
((())()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())
((()()()()()()())()()()()()()()())
((()()()()()()()()()())())
((()()()()())()()()())
((()()()()()())()()()()()()()()()()())
((()()()()()()()()())()()())
((())()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())
((())()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())
((()()()())()()()())
((()()()()()()()()())()())
((()()())()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())
((()()()()())()()()()()()()()()()()()()()())
((())()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())
((()()()())()()()())
((()()()()()()()())()()()()())
((())()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())
((()()()()()())()()()()()()()()()()()()())
((())()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()())
((()())()()()()()()()()()()()()()()()()()()()()()()()()()()()()()){({}<>)({<({}[()])><>({})<>}{}<><{}><>)<>}<>

Pruébalo en línea!


Cada fila representa un personaje que se está jugando al golf, esto supera la solución básica que publiqué en un 60% , y al no saber literalmente nada sobre Brainflak, creo que esta es una buena base de lo que no se debe hacer. Calificaré la respuesta dentro de poco, en medio de otra cosa y estoy seguro de que puedo mejorar en esto. (Incluyo las nuevas líneas en el conteo de bytes porque no espero que esto gane).


Aquí hay algunos consejos: 1) Si está presionando dos números (digamos 4 y 5 para obtener 20), entonces podría juntarlos para guardar bytes. Compare (()()()())(()()()()())y ((()()()())())2) La multiplicación por una constante puede ser mucho más corta que push(); multiply();. Por ejemplo, para duplicar un número, puede hacer en (({}){})lugar de (()())({}<>)({<({}[()])><>({})<>}{}<><{}>). Pero esta no es una línea de base terrible. Si quieres más información, siempre estoy feliz de chatear en la tercera pila
James

@DJMcMayhem Honestamente estaba buscando usar deltas entre números, reiniciando después de cada delta negativo. Pero también veo la idea de las diferencias ... Estoy incorporando eso ahora ... hay otros problemas con esto que también estoy solucionando. Además, el código 05AB1E en sí mismo no está protegido, no es que importe, pero también quiero rehacerlo.
Magic Octopus Urn

Los casos de puntaje aún no están disponibles. Hará ping en una semana o 2 cuando publique (evite la solución de optimización de caso de prueba)
Christopher

@DJMcMayhem ¿Serían buenos divisores de deltas?
Urna mágica de pulpo

Los casos de prueba están fuera
Christopher

2

Brain-Flak

For each character (main loop)
(([])<{({}[()]<

Get the difference between the top two characters
(({}<>)<>[({})]<><({}<>)>)

Push an open paren on the other stack
<>(((((()()){}()){}){}){})

Retrieve difference
(<>{}<>)

Greater than zero
([(({})[(())])](<>)){({}())<>}{}{((<{}>))<>{}}{}<>{}

If
{{}

While non-zero
({

Add value if not 1
<(({})[()])>{()(<{}>)}{}

<

Divmod 2
({}(())(<()>)){({}[()]<({}([{}]()))>)}{}({}[({})])

Hold the div
({}<

Push the mod part
{({}[()]<
((((((()()){}()){}){}){})())
>)}{}

Put div down
>)

Open paren if div non-zero
(({}))
{(<({}<{}
(((((()()){}()){}){}){})
>)>)}{}

Less than 4
([([({})[()()()()](())])](<>)){({}())<>}{}{((<{}>))<>{}}{}<>{}

If
{{}

Make that many 1s
{({}[()]<
((((((()()){}()){}){}){})())
>)}{}

End if
((<()>))}{}

End loop puting number of times run on the stack
>}{})

For each close push and pop
{({}[()]<
((((()()()()()){}){}){}())(((((((()()()()()){}){}){}())){}{})()())
>)}{}

End if
((<()>))}{}

Less than zero
([([({})(())])](<>)){({}())<>}{}{((<{}>))<>{}}{}<>{}

If
{{}

([{}]<

Push open bracket
((((((()()){}()){}()){}){}()){}())

>)

While non-zero
({

Add value if not 1
<(({})[()])>{()(<{}>)}{}

<

Divmod 2
({}(())(<()>)){({}[()]<({}([{}]()))>)}{}({}[({})])

Hold the div
({}<

Push the mod part
{({}[()]<
((((((()()){}()){}){}){})())
>)}{}

Put div down
>)

Open paren if div non-zero
(({}))
{(<({}<{}
(((((()()){}()){}){}){})
>)>)}{}

Less than 4
([([({})[()()()()](())])](<>)){({}())<>}{}{((<{}>))<>{}}{}<>{}

If
{{}

Make that many 1s
{({}[()]<
((((((()()){}()){}){}){})())
>)}{}

End if
((<()>))}{}

End loop puting number of times run on the stack
>}{})

For each close push and pop
{({}[()]<
((((()()()()()){}){}){}())(((((((()()()()()){}){}){}())){}{})()())
>)}{}

Push close bracket
((((((()()){}()){}()){}()){}){}())

Endif
((<()>))}{}{}

Remove top character
<>{}

End of main loop
>)}{}{}

Close the open parens
<>>){({}[()]<(((((()()){}()){}){}){}())>)}{}

Reverse code
([]){({}[()]<({}<>)<>>)}{}<>

Pruébalo en línea!

Salida para <your brain-flak code here>, 582 bytes:

([()((()(()(()()()){}){}){}){}]((()(()()){}){}([(()()()){}](()(()){}((()(((()(()()){}){}){}){}){}([(()((((()()){}){}){}){}){}]([(((()()){}){}){}](()(((()()){}){}){}([((()()){}){}]([()(()()){}](()(((((()()){}){}){}){}){}([()(((()(()()()){}){}){}){}]([(()()()){}](()(()(()()){}){}([(()(()()){}){}](()(()((()((()()){}){}){}){}){}([()(()((((()()){}){}){}){}){}]([((()()()){}){}](()(()(()()){}){}([()](()((()(((()()){}){}){}){}){}([(((()((()()){}){}){}){}){}](()(()){}([()((()()()){}){}](()((()()()){}){}(()(()(()((()()){}){}){}){}((()(()(()(()()()){}){}){}){})))))))))))))))))))))))))))
Al usar nuestro sitio, usted reconoce que ha leído y comprende nuestra Política de Cookies y Política de Privacidad.
Licensed under cc by-sa 3.0 with attribution required.