การขยายตัวของวงเล็บ!


36

ความท้าทายของคุณคือการขยายวงเล็บบางส่วนในอินพุตของโปรแกรมตามที่แสดง:

  1. ค้นหาสตริงsระหว่างวงเล็บที่ตรงกันสองตัว[และ]มีตัวเลขnหลักหลังวงเล็บปิด
  2. ลบวงเล็บ
  3. แทนที่sด้วยตัวเองซ้ำnครั้ง (ถ้าnคือ 0 ให้ลบs )
  4. ไปที่ขั้นตอนที่ 1 จนกว่าจะไม่มีวงเล็บที่ตรงกันในอินพุต

กฎและคำชี้แจงเพิ่มเติม:

  • คุณจะรับอินพุตและให้เอาต์พุตผ่านช่องทางที่อนุญาต
  • บรรทัดใหม่ต่อท้ายในเอาต์พุตได้รับอนุญาต
  • คุณต้องจัดการ ASCII ที่พิมพ์ได้ในอินพุตเท่านั้น
  • คุณอาจจะคิดว่าวงเล็บทั้งหมดตรงกันเช่นคุณจะไม่ได้รับการป้อนข้อมูลหรือ[]]]][[[[]
  • คุณอาจสมมติว่าวงเล็บปิดแต่ละตัว]มีตัวเลขหลังจากนั้น

กรณีทดสอบ:

Input                -> Output
[Foo[Bar]3]2         -> FooBarBarBarFooBarBarBar
[one]1[two]2[three]3 -> onetwotwothreethreethree
[three[two[one]1]2]3 -> threetwoonetwoonethreetwoonetwoonethreetwoonetwoone
[!@#[$%^[&*(]2]2]2   -> !@#$%^&*(&*($%^&*(&*(!@#$%^&*(&*($%^&*(&*(
[[foo bar baz]1]1    -> foo bar baz
[only once]12        -> only once2
[only twice]23456789 -> only twiceonly twice3456789
[remove me!]0        -> 
before [in ]2after   -> before in in after

เนื่องจากนี่คือคำตอบที่สั้นที่สุดในแต่ละภาษาจะเป็นผู้ชนะ โชคดี!


โพสต์ sandboxed
MD XF

13
คุณควรโพสต์ความท้าทายอื่นเพื่อบีบอัดสตริงกลับเป็นรูปแบบที่สั้นที่สุด
โจคิง

มันมีค่าที่ระบุอย่างชัดเจนว่าสตริงของคุณsไม่ควรมีวงเล็บอื่น ๆ ? ตัวอย่างเช่นการพยายามที่จะแก้ปัญหา[Foo[Bar]3]2โดยการขยายสตริงFoo[Bar3 ครั้งจะส่งผลให้สถานะไม่ถูกต้องFoo[BarFoo[BarFoo[Bar]2
BradC

@BradC นั้นทั้งหมดขึ้นอยู่กับวิธีที่คุณเลือกที่จะใช้งาน
MD XF

นั่นหมายความว่ามีคำตอบที่ถูกต้องสองข้อ[a[b]2c[d]2e]2ใช่ไหม คุณได้รับabbcddeabbcddeโดยการขยายbและdก่อน แต่ababcdbcdedbabcdbcdedeโดยการขยายa[bและd]2eก่อน
BradC

คำตอบ:


13

Gema , 17 ตัวอักษร

[#]?=@repeat{?;#}

วิ่งตัวอย่าง:

bash-4.4$ gema '[#]?=@repeat{?;#}' <<< '[three[two[one]1]2]3'
threetwoonetwoonethreetwoonetwoonethreetwoonetwoone

ว้าวพูดคุยเกี่ยวกับการหาภาษาที่เหมาะสมสำหรับงาน!
MD XF

หรืองานที่เหมาะสมสำหรับภาษา ความท้าทายหลายอย่างต้องข้ามเนื่องจากอาร์กิวเมนต์แบบเรียกซ้ำไม่ยืดหยุ่นเพียงพอ
จัดการ

การยอมรับสิ่งนี้เพราะตอนนี้ฉันไม่เห็นว่ามันจะถูกเอาชนะ แต่จะไม่ได้รับการยอมรับในกรณีที่ไม่น่าเป็นไปได้
MD XF


7

Haskell , 101 96 ไบต์

fst.(""%)
infix 4%
s%']':d:r=(['1'..d]>>s,r)
s%'[':r|(t,q)<-""%r=s++t%q
s%x:r=s++[x]%r
s%e=(s,e)

ลองออนไลน์! แทนที่จะใช้การแสดงออกปกติเหมือนกับคำตอบอื่น ๆ ส่วนใหญ่จะใช้เครื่องมือแยกวิเคราะห์ซ้ำ

-5 ไบต์ขอบคุณBMO !


4
ประกาศ fixity สำหรับ(%)ช่วยให้คุณประหยัด 1 ไบต์และ['1'..d]ช่วยให้คุณประหยัดอีก 4 ดูนี้
ბიმო

3
@BMO ดีฉันไม่ได้คาดหวังว่าการประกาศ fixity จะเป็นประโยชน์สำหรับการเล่นกอล์ฟรหัส ฉันคิดว่าคุณควรเพิ่มเข้าไปในคำถามเคล็ดลับ
Laikoni

7

Perl 5 , 34 33 29 + 1 ( -p) = 30 ไบต์

s/.([^[]*?)](.)/$1x$2/e&&redo

ลองออนไลน์!

ลดความมันลงไปด้วยความช่วยเหลือจาก @Shaggy และ @TonHospel


3
ฉันไม่รู้จักมุก แต่การทำซ้ำดูเหมือนจะงดงาม!
อย่างเป็นทางการ

]ฉันคิดว่าคุณควรจะสามารถที่จะบันทึกไบต์โดยไม่ได้หลบหนี
Shaggy

1
ผมไม่ทราบว่า Perl แต่นี้ ดูเหมือนว่าการทำงานเป็นเวลา 30 + 1 ไบต์
Shaggy

2
เหล่านี้ทำงาน 29 + 1 ยัง: perl -pe 's/.([^[]*?)](.)/$1x$2/e&&redo'และperl -pe 's/.([^][]*)](.)/$1x$2/e&&redo'
Ton Hospel

5

Japt v2 , 21 20 19 ไบต์

บันทึก 2 ไบต์ขอบคุณ @Shaggy

e/.([^[]*?)](./@YpZ

ทดสอบออนไลน์!

eเป็นการแทนที่แบบเรียกซ้ำซึ่งจะทำการแทนที่ทีละครั้งจนกว่าจะไม่มีการแข่งขันเพิ่มเติม ในกรณีนี้การจับคู่ของ regex /\[([^[]*?)](\d)/gจะถูกแทนที่ด้วย <Inner text> ซ้ำ <digit> ครั้งจนกว่าจะไม่มีการจับคู่เพิ่มเติม

ตามที่ฉันได้วางแผนไว้ ( ที่นี่ ) ในที่สุด regex นี้ควรสั้นลงอย่างน้อย3 2 ไบต์:

‹[“⁽[»₋”]“.›

2
ในฐานะที่เรา " อาจคิดว่าแต่ละวงเล็บปิด]มีหลักหลังจากที่มัน " คุณควรจะสามารถที่จะแทนที่ด้วย(\d (.
Shaggy

คุณสามารถแทนที่\[ด้วย.
Shaggy

@Shaggy ดีขอบคุณ!
ETHproductions

4

JavaScript, 71 67 66 ไบต์

ฉันมีวิธีการแก้ปัญหา 54 ไบต์ แต่มันถูกเมาโดยกรณีทดสอบที่สอง! :(

f=s=>s!=(x=s.replace(/.([^[]*?)](.)/,(_,y,z)=>y.repeat(z)))?f(x):x

กรณีทดสอบ

f=s=>s!=(x=s.replace(/.([^[]*?)](.)/,(_,y,z)=>y.repeat(z)))?f(x):x
o.innerText=`[Foo[Bar]3]2
[one]1[two]2[three]3
[three[two[one]1]2]3
[!@#[$%^[&*(]2]2]2
[[foo bar baz]1]1
[only once]12
[only twice]23456789
[remove me!]0
before [in ]2after`.split`\n`.map(x=>x.padEnd(22)+`:  `+f(x)).join`\n`
<pre id=o></pre>


4

Python 3 , 110 93 92 ไบต์

import re
f=lambda s:f(re.sub(r'\[([^][]+)\](.)',lambda m:m[1]*int(m[2]),s))if'['in s else s

ลองออนไลน์!

-17 ไบต์ขอบคุณ pizzapants184 -1 ไบต์ขอบคุณ Kevin Cruijssen


1
-17 ไบต์ในหลาม 3ที่มีการจัดทำดัชนีและ re.match substring inการตรวจสอบการใช้
pizzapants184

1
-1 ไบต์โดยเปลี่ยน(\d)เป็น(.)เพราะเรารู้ว่าตัวยึดบล็อก]นั้นตามด้วยหลักเสมอ
Kevin Cruijssen

4

สกาลา , 173 ไบต์

l.foreach{x=>def r(c:String):String={val t="""\[([^\[\]]*)\](.)""".r.unanchored;c match{case t(g,h)=>r(c.replaceAllLiterally(s"[$g]$h",g*h.toInt));case _=>c}};println(r(x))}

ลองออนไลน์!

ขยาย:

l.foreach { x =>
  def remove(current: String): String = {
    val test ="""\[([^\[\]]*)\](.)""".r.unanchored
    current match {
      case test(g, h) => remove(current.replaceAllLiterally(s"[$g]$h", g * h.toInt))
      case _ => current
    }
  }

  println(remove(x))
}

วิธีการแก้ปัญหาเก่า

สกาลา , 219 215 213 212 199ไบต์

l.foreach{x=>def r(c:String):String={"""\[([^\[\]]*)\](.)""".r.findFirstMatchIn(c).map{x=>val g=x.group(1);val h=x.group(2).toInt;r(c.replaceAllLiterally(s"[$g]$h",g*h))}.getOrElse(c)};println(r(x))}

ลองออนไลน์!

ขยาย:

l.foreach { x =>
  def remove(current: String): String = {
    """\[([^\[\]]*)\](.)""".r.findFirstMatchIn(current).map { x =>
      val g = x.group(1)
      val h = x.group(2).toInt
      remove(current.replaceAllLiterally(s"[$g]$h", g * h))
    }.getOrElse(current)
  }
  println(remove(x))
}

โดยที่ l คือรายการสตริงที่เราจะประมวลผล

ขอบคุณ Kevin Cruijssen สำหรับ -1 ไบต์

ไปจาก 212 ถึง 199 โดยการลบพารามิเตอร์ที่ไม่ได้ใช้ไม่ได้ใส่ใจ


4
ยินดีต้อนรับสู่ PPCG! ลองล่ามสกาล่าของ tio ที่tio.run/#scalaและดูว่าคุณสามารถส่งลิงค์สำหรับคำตอบเพื่อให้คนอื่น ๆ สามารถลองออนไลน์ได้หรือไม่ :)
เป็นทางการเมื่อ

2
ขอขอบคุณ! ฉันแก้ไขคำตอบเพื่อรวมลิงค์ หวังว่ามันจะโอเคที่จะประกาศส่วนหัว, รหัสและท้ายกระดาษเพื่อการส่งที่เหมาะสม
Shikkou

1
สวัสดียินดีต้อนรับสู่ PPCG! คำตอบแรกที่ดี +1 จากฉัน ฉันคิดว่าคุณสามารถบันทึกได้ 1 ไบต์โดยเปลี่ยน(\d)เป็น(.)เพราะเรารู้ว่าตัวยึดบล็อก]นั้นตามด้วยหลักเสมอ
Kevin Cruijssen

3

ซ้อนกัน , 39 38 ไบต์

บันทึก 1 ไบต์ขอบคุณ Shaggy, golfed the regex!

['\[([^[\]]+)](.)'{.y x:x#~y*}recrepl]

ลองออนไลน์!

เพียงแค่แทนที่ regex '\[([^[\]]+)](.)'ซ้ำด้วยกฎการทำซ้ำ


]ฉันคิดว่าคุณสามารถบันทึกไบต์โดยไม่ได้หลบหนีสุดท้าย
Shaggy

3

Python 3, 155 148 101 97 ไบต์

def f(x):
 a=x.rfind('[')
 if~a:b=x.find(']',a);x=f(x[:a]+x[a+1:b]*int(x[b+1])+x[b+2:])
 return x

ลองใช้ออนไลน์

ขอบคุณ HyperNeutrino และ Mego สำหรับ -47 ไบต์และ user202729 สำหรับ -4 ไบต์


ทำให้เป็นสายการบินเดียวที่จะช่วยประหยัดไบต์คู่:def f(x):a=x.rfind('[');b=x.find(']',a);return f(x[:a]+x[a+1:b]*int(x[b+1])+x[b+2:])if~a else x
mathmandan

3

JavaScript - 77 75 72 ไบต์

f=a=>a.replace(/(.*)\[([^[]*?)](.)(.*)/,(a,b,c,d,e)=>f(b+c.repeat(d)+e))

แก้ไข: อัปเดต regex พร้อมคำแนะนำของ Shaggy

ตัวอย่างข้อมูล:


2
ยินดีต้อนรับสู่ PPCG! คุณสามารถลดขนาดให้เหลือ70 ไบต์ได้โดยปรับแต่ง RegEx ของคุณ
Shaggy

ใช่ 72 ไบต์แน่นอนขอโทษด้วย ฉันลืมนับf=!
Shaggy

2

QuadRพร้อมอาร์กิวเมนต์30 28 ไบต์

\[[^[]+?].
∊(⍎⊃⌽⍵M)⍴⊂1↓¯2↓⍵M

ลองออนไลน์!

\[[^[]+?]. แทนที่ " ตัวละครที่[ไม่ใช่[สิ่ง]" ด้วย

¯2↓⍵M วางตัวละครสองตัวสุดท้ายของM atch ( " ]หลัก ')
1↓ ลดลงอักขระตัวแรก (' [")
 ล้อมรอบที่จะถือว่าเป็นทั้ง
(... )⍴R eshape ความยาว:
⌽⍵M กลับM atch
 เลือกแรก (หลัก)
 ประเมิน
ε nlist ( เรียบ)

 ทำซ้ำจนกว่าจะไม่มีการเปลี่ยนแปลงเกิดขึ้นอีก


ฟังก์ชัน Dyalog APL ที่เทียบเท่าคือ 47 ไบต์:

'\[[^[]+?].'R{∊(⍎⊃⌽⍵.Match)⍴⊂1↓¯2↓⍵.Match}⍣≡

ลองออนไลน์!


2

Java 8, 250 249 241 239 ไบต์

s->{for(;s.contains("[");)for(int i=0,j,k;i<s.length();)if(s.charAt(i++)==93){String t="",r=t;for(j=k=s.charAt(i)-48;j-->0;)t+=s.replaceAll(r="(.*)\\[([^\\]]+)\\]"+k+"(.*)","$2");s=k<1?t:s.replaceFirst(r,"$1$3").replace("",t);}return s;}

-2 ไบต์ต้องขอบคุณ@JonathanFrech (รหัสประกอบด้วยอักขระ ASCII ที่ไม่สามารถพิมพ์ได้สองตัวในขณะนี้ซึ่งสามารถเห็นได้ในลิงก์ TIO ด้านล่าง)

เฮ้อ ... Java กับ regex นั้น จำกัด มากเลย .. ฉันจะอ้างอิงตัวเองจากคำตอบอื่นที่นี่:

การแทนที่WWWWด้วย222WJava เป็นเรื่องง่าย แต่4Wไม่ใช่ ..ถ้าเพียง Java มีวิธีใช้กลุ่มจับภาพ regex สำหรับบางสิ่ง .. รับความยาวด้วย"$1".length(), แทนที่การจับคู่ด้วยตัวเอง"$1".replace(...), เปลี่ยนการจับคู่เป็นจำนวนเต็มด้วยnew Integer("$1")หรือใช้ สิ่งที่คล้ายกับ Retina (เช่นs.replaceAll("(?=(.)\\1)(\\1)+","$#2$1"))หรือ JavaScript (เช่นs.replaceAll("(.)\\1+",m->m.length()+m.charAt(0))) จะเป็นหมายเลข 1 ของฉันสิ่งที่ฉันต้องการเห็นใน Java ในอนาคตเพื่อรับประโยชน์ codegolfing .. >.> ฉันคิดว่านี่เป็นเวลา 10+ ที่เกลียดชัง Java อะไรก็ได้ที่มีการจับคู่แบบจับภาพกลุ่ม
อ้างอิงจากที่นี่

คำอธิบาย:

ลองออนไลน์

s->{                           // Method with String as both parameter and return-type
  for(;s.contains("[");)       //  Loop as long as the String contains a block-bracket
    for(int i=0,j,k;i<s.length();)
                               //   Inner loop over the characters of the String
      if(s.charAt(i++)==93){   //    If the current character is a closing block-bracket:
        String t="",r=t;       //     Create two temp-Strings, starting empty
        for(j=k=s.charAt(i)-48;//     Take the digit after the closing bracket
            j-->0;)            //     Loop that many times:
          t+=s.replaceAll(r="(.*)\\[([^\\]]+)\\]"+k+"(.*)","$2");
                               //      Append `t` with the word inside the block brackets
        s=k<1?                 //     If the digit was 0:
           t                   //      Replace the input with an empty String as well
          :                    //     Else:
           s.replaceFirst(r,"$1$3").replace("",t);}
                               //      Replace the word between brackets by `t`,
                               //      and remove the digit
  return s;}                   //  Return the modified input-String as result

1
ฉันคิดว่าคุณสามารถใช้ ASCII อย่างแท้จริงแม้ว่าตัวละครไม่สามารถพิมพ์เพื่อประหยัดไบต์ที่สอง (วิธีการแก้ปัญหาของคุณใช้เวลา 241 ไบต์, 239 ตัวอักษร)
Jonathan Frech

@ JonathanFrech ขอบคุณ! กำลังมองหาอักขระ 1 ไบต์นอกช่วง ASCII ที่พิมพ์ได้ ไม่ได้คิดเกี่ยวกับการใช้ unprintable ..
เควิน Cruijssen


2

C, 407 368 ไบต์

ขอบคุณ Jonathan Frech สำหรับการบันทึกไบต์

golfed (ไฟล์ bracket.c):

i,j,k,l,n;char*f(a,m)char*a;{for(i=0;a[i];++i){a[i]==91&&(j=i+1);if(a[i]==93){k=a[i+1]-48;if(!k){for(l=i+2;l<m;)a[++l-i+j-4]=a[l];a=realloc(a,m-3);return f(a,m-3);}for(l=j;l<i;)a[~-l++]=a[l];for(l=i+2;l<m;)a[++l-4]=a[l];m-=3;n=m+~-k*(i---j--);a=realloc(a,n);for(l=i;l<m;)a[l+++~-k*(i-j)]=a[l];for(m=0;m<k;++m)for(l=j;l<i;)a[l+++m*(i-j)]=a[l];return f(a,n);}}return a;}

ungolfed ด้วยโปรแกรม:

#include <stdlib.h>
#include <stdio.h>

// '[' = 133
// ']' = 135
// '0' = 48

i, j, k, l, n;

char* f(a,m) char*a;
{
  for (i=0; a[i]; ++i) {
    a[i]==91&&(j=i+1);

    if (a[i]==93) {
      k=a[i+1]-48;

      if (!k) {
        for (l=i+2; l<m; )
          a[++l-i+j-4] = a[l];

        a = realloc(a,m-3);
        return f(a,m-3);
      }
      for (l=j;l<i;)
        a[~-l++] = a[l];
      for (l=i+2; l<m; )
        a[++l-4] = a[l];
      m -= 3;
      n = m+~-k*(i---j--);
      a = realloc(a,n);

      for (l=i; l<m; )
        a[l+++~-k*(i-j)] = a[l];
      for (m=0; m<k; ++m)
        for (l=j; l<i;)
          a[l+++m*(i-j)] = a[l];

      return f(a,n);
    }
  }
  return a;
}

int main()
{
  char c[]="[Foo[Bar]3]2";
  char *b;

  char cc[]="[remove me!]0";
  char *bb;

  char ccc[]="[only once]12";
  char *bbb;

  b=malloc(13);
  bb=malloc(14);
  bbb=malloc(14);

  for (i=0; i<13; ++i)
    b[i] = c[i];

  for (i=0; i<14; ++i)
    bb[i] = cc[i];

  for (i=0; i<14; ++i)
    bbb[i]=ccc[i];

  printf("%s\n", f(b, 13));
  printf("%s\n", f(bb, 14));
  printf("%s\n", f(bbb, 14));

  return 0;
}

รวบรวมด้วย gcc 5.4.1 gcc bracket.c


1
368 ไบต์
Jonathan Frech

387 ที่มีการรวมที่จำเป็น (สำหรับ realloc) ฉันจะทำการอัพเดทใหม่ทั้งหมด (ด้วยเวอร์ชั่นที่ไม่อัปโหลด) ในภายหลัง ขอบคุณ
Tsathoggua

หากคุณใช้ GCC ฉันคิดว่าคอมไพเลอร์จะพยายามเดาความหมายของทั้งสองmallocและreallocรวมถึงstdlib.hของตัวเอง
Jonathan Frech

ฉันไม่รู้ คุณสมบัติที่ดีสำหรับการตีกอล์ฟ ขอบคุณ
Tsathoggua

2

สีแดง , 147 ไบต์

f: func[t][a: charset[not"[]"]while[parse t[any a some[remove["["copy h any a"]"copy d a](insert/dup v: copy""h to-integer d)insert v | skip]]][]t]

Ungolfed:

f: func [t][
    a: charset [not "[]"]                          ; all chars except [ and ]
    while [ parse t [                              ; repeat while parse is returning true
        any a                                      ; 0 or more chars other than [ and ]
        some [                                     ; one or more block:
            remove ["[" copy h any a "]" copy d a] ; remove the entire block, store the
                                                   ; substring between the [] in h,
                                                   ; the digit into d
            (insert/dup v: copy "" h to-integer d) ; makes d copies of h 
            insert v                               ; and inserts them in place 
            | skip ]                               ; skip if no match
        ]                                       
    ][]                                            ; empty block for 'while'
    t                                              ; return the modified string
]

ฉันเริ่มเรียนรู้ภาษาของการแยกวิเคราะห์ของเรดเมื่อวานนี้เท่านั้นดังนั้นฉันจึงมั่นใจว่ารหัสของฉันสามารถปรับปรุงได้อีก การแยกวิเคราะห์มีความละเอียดมากกว่า regex อย่างชัดเจน แต่มีความชัดเจนยืดหยุ่นและสามารถอ่านได้และสามารถผสมกับภาษาส่วนที่เหลือได้อย่างอิสระ

ลองออนไลน์!


1

เยลลี่ 30 ไบต์

œṡ”]µḢUœṡ”[ẋ€1¦Ṫ©Ḣ$FṚ;®
Çċ”]$¡

ลองออนไลน์!


คำอธิบาย


œṡ”]µḢUœṡ”[ẋ€1¦Ṫ©Ḣ$FṚ;®    Helper link 1, expand once.
                           Assume input = "ab[cd]2ef".

œṡ      Split at first occurence of
  ”]      character "]".
    µ   Start new monadic chain. Value = "ab[cd","2ef".

Ḣ       ead. "ab[cd"
 U      Upend. "dc[ba"
  œṡ”[  Split at first occurence of "[". | "dc","ba".

ẋ€        Repeat ...
  1¦        the element at index 1...
          by ...
    Ṫ Ḣ$    the ead of the ail of ...
          the input list ("ab[cd","2ef") (that is, 2)

          The command  also pop the head '2'. The remaining
            part of the tail is "ef".
     ©    Meanwhile, store the tail ("ef") to the register.

          Current value: "dcdc","ba"
FṚ        Flatten and everse. | "abcdcd"
  ;®      Concatenate with the value of the register. "abcdcdef"

Çċ”]$¡    Main link.

 ċ”]$     Count number of "]" in the input.
     ¡    Repeatedly apply...
Ç           the last link...
            that many times.

1

C, 381 ไบต์

รุ่นกะทัดรัด:

while(1){int t=strlen(i);int a,c=-1;char*w;char*s;char*f;while(c++<t){if(i[c]==']'){int k=c-a;w=calloc((k--),1);memcpy(w,&i[a+1],k);s=calloc((t-c-1),1);memcpy(s,&i[c+2],t-c-2);i[a]=0;int r=i[c+1]-48;if(r==0){f=calloc(t,1);sprintf(f,"%s%s",i,s);}else{f=calloc((t+k),1);sprintf(f,"%s%s[%s]%d%s",i,w,w,r-1,s);}free(i);i=f;break;}else if(i[c]=='[')a=c;}free(w);free(s);if(c>=t)break;}

เวอร์ชันเต็ม:

#include <string.h>
#include <stdio.h>
#include <stdlib.h>

void proceed(char* input)
{
  while(1)
  {
    int t=strlen(input);
    int start,cursor=-1;
    char* word;
    char* suffix;
    char* final;
    while(cursor++<t)
    {
      if(input[cursor]==']')
      {
        int wordlength = cursor-start;
        word=calloc((wordlength--),sizeof(char));
        memcpy(word, &input[start+1], wordlength );
        suffix=calloc((t-cursor-1),sizeof(char));
        memcpy( suffix, &input[cursor+2], t-cursor-2 );
        input[start]='\0';
        int rep=input[cursor+1]-'0';
        if(rep==0)
        {
          final=calloc(t,sizeof(char));
          sprintf(final,"%s%s",input,suffix);
        }
        else
        {
          final=calloc((t+wordlength+5),sizeof(char));
          sprintf(final,"%s%s[%s]%d%s",input,word,word,rep-1,suffix);
        }
        free(input);
        input=final;
        break;
      }
      else if(input[cursor]=='[')
        start=cursor;
    }
    free(word);
    free(suffix);

    if(cursor>=t)break;
  }
}

int main()
{
  char* input=calloc(256,sizeof(char));
  sprintf(input,"a[[toto]2b]2[ana]3");
  printf("in : %s\n",input);
  proceed(input);
  printf("out: %s\n",input);
  return 0;
}

3
ยินดีต้อนรับสู่ PPCG!
Shaggy

1
ยินดีต้อนรับสู่เว็บไซต์! โปรดทราบว่าการส่ง C ต้องเป็นโปรแกรมหรือฟังก์ชั่นเต็มรูปแบบไม่ใช่แค่ตัวอย่าง
MD XF

1

Python 80 ไบต์

import re
b=re.sub
s=lambda x:eval(b(r"\](.)",r"')*\1+'",b(r"\[","'+('","%r"%x)))

ลองออนไลน์!

s("[Foo[Bar]3]2")แปลง[Foo[Bar]3]2เป็น''+('Foo'+('Bar')*3+'')*2+''และประเมินผล

ล้มเหลวในการป้อนข้อมูลด้วยเครื่องหมายคำพูดในวงเล็บ (เช่น[']3)


ฉันลงคะแนนคำตอบนี้เนื่องจากคำถามต้องการจัดการ ASCII ที่พิมพ์ได้ในอินพุตและคำตอบนี้ไม่ได้ แจ้งให้ฉันทราบหากคุณแก้ไขและฉันจะถอนการลงคะแนนของฉันอย่างมีความสุข
caird coinheringaahing
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.