Zamień alias, aby utworzyć frazy

9

Inspirowany przez C -Dyrektywa #define.

Wyzwanie

Podano jedną frazę z pewnym aliasem i jedną tablicę z każdym tekstem aliasu. Wypisz początkową frazę zastępując każdy alias odpowiednim tekstem.

Alias ​​jest definiowany przez jeden kursor, #po którym następuje jego indeks w tablicy (indeks może zaczynać się od zera lub jeden). Alias ​​może zawierać inny alias w tekście i musisz je wszystkie rozwiązać (być może rekurencyjnie). Możesz założyć, że alias nigdy nie będzie działał w nieskończonej pętli. Alias ​​nie będzie miał początkowych zer ( #02nie jest aliasem w indeksie 2, jest aliasem w indeksie, 0po którym następuje tekst 2).

Możesz założyć, że tablica nie przejdzie 20 elementów.

Możesz napisać program, funkcję lub nawet #define- byłoby miło :)

Możesz także użyć innej metody wprowadzania, która lepiej pasuje do Twojego języka.

Przykład

phrase: "#0 & #3"
array: [
    "Programming #1",
    "Puzzles",
    "Code",
    "#2 Golf"
]
output: "Programming Puzzles & Code Golf"

Krok po kroku:

0> "#0 & #3"
1> "Programming #1 & #2 Golf"
2> "Programming Puzzles & Code Golf"

Ponieważ tak jest , najkrótsza odpowiedź w bajtach wygrywa!

Kolejne próbki

phrase: "#0!"
array: [
    "We are #1",
    "#2",
    "#3",
    "#4 !",
    "graduating"
]
output: "We are graduating !!"

phrase: "##0#1#0#21#3#4"
array: [
    "a",
    "m",
    "z",
    "n",
    "g"
]
output: "#amaz1ng"

phrase: "##1#23"
array: [
    "WEIRD",
    "0 C",
    "AS"
]
output: "WEIRD CAS3"

phrase: "#1#7#6y#4#7#10s#7b#11#0#0#11r#7#0h#6#5#2#5#9#4."
array: [
    "t",
    "#12#3",
    "#11ga#3",
    "#0#10v#11",
    "#0h#10#8g",
    "#7#8",
    "a#8",
    " ",
    "n",
    "o",
    "i",
    "e",
    "P#9s#10"
]
output: "Positive anything is better than negative nothing."

W powyższych przykładach użyto tablicy z indeksem rozpoczynającym się od zera.

oddalony
źródło
Jeśli użyjemy opcji indeksowania 1, czy nie musimy się martwić, że wiodąca 0 #0nie powinna się pojawić? Czy jest #01poprawny, ale nie jest aliasem (tzn. Po prostu zostaje w niezmienionej postaci)?
FryAmTheEggman
@FryAmTheEggman. W takim przypadku należy po prostu zignorować#01
usunięto
Łatwe z python dla 0-9, umysł oszałamiający, próbując zminimalizować 0-19: D
Antti Haapala
1
W tym, co wydaje się prostym problemem, kryje się zaskakująca złożoność. Świetne pytanie!
Josh

Odpowiedzi:

4

JavaScript (ES6) 58

Funkcja rekurencyjna

f=(s,h,r=s.replace(/#(1?\d)/g,(_,x)=>h[x]))=>r==s?r:f(r,h)

Test

f=(s,h,r=s.replace(/#(1?\d)/g,(_,x)=>h[x]))=>r==s?r:f(r,h)

// Version without default parameters, same length but using a global
// f=(s,h)=>(r=s.replace(/#(1?\d)/g,(_,x)=>h[x]))==s?r:f(r,h)

console.log=x=>O.textContent+=x+'\n'

;[
  ['##1#23',['WEIRD','0 C','AS']],
  ["#0!",["We are #1","#2","#3","#4 !","graduating"]],
  ["##0#1#0#21#3#4",["a","m","z","n","g"]],
  ["##0#1#0#21#13#4",["a","m","z","","g","","","","","","","","","n"]],
  ["#1#7#6y#4#7#10s#7b#11#0#0#11r#7#0h#6#5#2#5#9#4.",
    ["t","#12#3","#11ga#3","#0#10v#11","#0h#10#8g","#7#8","a#8"," ","n","o","i","e","P#9s#10"]
  ],
  ["#0 & #3",["Programming #1","Puzzles","Code","#2 Golf"]]
].forEach(t=>{
  var a=t[0],b=t[1]
  console.log(a+' ['+b+']\n -> '+f(a,b))
})
<pre id=O></pre>

edc65
źródło
Dodałem kolejny przypadek testowy o indeksie aliasu większym niż 9.
usunięto
2

Mathematica, 74 bajty

FixedPoint[#~StringReplace~a&,a=0;a=Reverse["#"<>ToString@a++->#&/@#2];#]&

Niezbyt skomplikowane. Większość z nich jest po prostu poświęcona tworzeniu indeksów.

LegionMammal978
źródło
1
@WashingtonGuedes Naprawiono.
LegionMammal978
2

Julia, 112 107 66 bajtów

f(s,x)=(r=replace(s,r"#1?\d",m->x[1+parse(m[2:end])]))==s?s:f(r,x)

Jest to funkcja rekurencyjna, która przyjmuje ciąg znaków do tablicy i zwraca ciąg znaków. Korzysta z indeksowania opartego na 0.

Zaczynamy od skonstruowania ciągu r jako ciągu wejściowego s ze wszystkimi dopasowaniami wyrażenia regularnego #1?\dzastąpionymi elementem x odpowiadającym 1 + liczba całkowita przeanalizowana poza dopasowanie. Jeśli jest to równe s , zwracamy s , w przeciwnym razie ponawiamy, przekazując r jako ciąg.

Alex A.
źródło
1

C 269 232

#define f(p,a,l)char*n,o[999],i=0,c,x;for(strcpy(o,p);o[i];)o[i]==35&isdigit(o[i+1])?c=o[i+1]-48,c=isdigit(o[i+2])&c?10*c+o[i+2]-48:c,n=a[c<l?c:c/10],x=strlen(n),memmove(o+i+x,o+i+2+c/10,strlen(o+i)),i=!memmove(o+i,n,x):++i;puts(o);

Zgodnie z życzeniem, jedno #definerozwiązanie problemu! Makra C nie mogą być rekurencyjne, więc problem musiał zostać rozwiązany iteracyjnie. Makro przyjmuje 3 argumenty; fraza p, tablica ai długość tablicy l. Usunąłem tylko białe spacje z mojego niegolfowanego rozwiązania; Wiem, że jest jeszcze kilka postaci, które mogę uratować, ale nie sądzę, że spadnie to poniżej 200. To zdecydowanie nie będzie konkurencyjne rozwiązanie. Rozwiązanie jest w pełni golfem. Niegolfowane rozwiązanie w postaci funkcji poniżej:

f(char*p,char**a,int l){
  char o[999]={0},i=0;
  strcpy(o,p);
  while(o[i]){
    if(o[i]=='#'&&isdigit(o[i+1])){
      int c = o[i+1]-'0';
      if(isdigit(o[i+2])&&c)
        c=10*c+o[i+2]-'0';
      if(c>=l)
        c/=10;
      char *n=a[c];
      memmove(o+i+strlen(n),o+i+2+c/10,strlen(o+i));
      memmove(o+i,n,strlen(n));
      i=0;
    }else{
      i++;
    }
  }
  puts(o);
}

I kod testowy:

void test(char *phrase, char **array, int length) {
  f(phrase, array, length);
}

main() {
  const char *t1[] = {
    "Programming #1","Puzzles","Code","#2 Golf"
  };
  test("#0 & #3", t1, 4);

  const char *t2[] = {
    "We are #1","#2","#3","#4 !","graduating"
  };
  test("#0!", t2, 5);

  const char *t3[] = {
    "a","m","z", "n","g"
  };
  test("##0#1#0#21#3#4", t3, 5);

  const char *t4[] = {
    "WEIRD","0 C","AS"
  };
  test("##1#23", t4, 3);

  const char *t5[] = {
    "t","#12#3","#11ga#3","#0#10v#11","#0h#10#8g","#7#8","a#8"," ","n","o","i","e","P#9s#10"
  };
  test("#1#7#6y#4#7#10s#7b#11#0#0#11r#7#0h#6#5#2#5#9#4.", t5, 13);
}

EDYCJA: trochę magii golfa. Jest tak krótki i nieczytelny, jak mi się wydaje.

Josh
źródło
Człowieku, miły !!! ... głosowałbym jeszcze raz, gdybym mógł;)
usunąłem