XKCDタイプに適合するインターフェースを作成します


34

colors.rgb( "blue")は、 "#0000FF"を生成します。colors.rgb( "yellowish blue")はNaNを生成します。colors.sort()は「rainbow」を生成します

画像とそのタイトルテキスト(ここで引用)に設定されているルールを使用して、指定されたすべての入力を受け入れ、適切な出力を表示するプログラムを作成します。

  • 入力は、stdinまたはそれに最も近いもので取得できます。[n]>入力するような行があり、nコマンドごとに1つずつ増加します。1から開始する必要があります。

  • 結果は、stdoutまたは最も近いものを使用して表示する必要があります。=>出力の各行にが必要です。

13の条件すべてに加えて、タイトルの3(引用)が機能する必要があります。

これはコードゴルフなので、最短の回答が勝ちます。


16
インターフェイスはどの程度一般的ですか?たとえば、floor関数は提供されたフロートに対して機能する必要があり10.5ますか、それが渡されるだけだと想定できますか?
アンク-morpork

1
nが大きくなり、入力が右に移動するにつれて、出力の>が入力の>に揃えられますか?
SPARR

1
このコミックは、いくつかの方法で解釈される可能性があります。実装する必要がある特定のタイプと操作のリストを提供してもらえますか?
BrainSteel

5
なぜn1増やす必要があるのですか?それはコミックがすることではありません... ;
モニカを復活させる

3
@WolframHそれは-しかし、彼はコマンド11で2 = 4にしたので、12ではなく14を表示します。-
ティム

回答:


21

Python 3、700 698 697 689 683 639 611

インデントとしてのタブ。

from ast import*
E=literal_eval
O='=>%s\n'
P=print
I=int
def Q(a):P(O%a)
def W(a):Q('"%s"'%str(a))
def gb(a):W(_ if'y'in a else'#0000FF')
def t():W('rainbow')
def FLOOR(n):P(O%'|'*3+(O%'|{:_^10}').format(n))
def RANGE(*a):Q([('"','!',' ','!','"'),(1,4,3,4,5)][len(a)])
c=0
while 1:
    try:
        c+=1;A,*B=input('[%d]>'%c).split('+')
        if not A:W(c+I(B[0]))
        elif A=='""':Q("'\"+\"'")
        elif B:
            A=E(A);B=E(B[0])
            if A==B:Q('DONE')
            elif type(A)==list:Q(A[-1]==B-1)
            elif type(B)==list:W([I(A)])
            else:W(A+I(B))
        else:eval(A.lstrip('colrs.'))
    except:Q('Na'+['N','P','N.%s13'%('0'*13)][('-'in A)+len(B)])

これは裸の例外を使用するため、Ctrl-Cを使用できません。Ctrl-Zとキル%%の作業

一部の条件は一般化されており、他の条件は正確な入力でのみ機能します。

  1. A+"B" いつでもAとBで動作します A == B
  2. "A"+[] intに変換できる任意のAで機能します(0xffや0b01010などの16進数およびバイナリ文字列を含みます)
  3. (A/0)DivideByZeroError以外で処理されるA、Eval Causeに対して機能します
  4. (A/0)+BAまたはBで動作します。literal_eval(E)エラーが発生します。
  5. ""+""+記号に対してのみ機能します。それ以外は、NaN、NaP、またはNaN.00を出力します...
  6. [A, B, C]+DD == C+1リストの任意の長さおよび任意の数値で機能することを確認することで機能します。
  7. ^^
  8. 2/(2-(3/2+1/2))、解析に失敗し-て、+NaN.000 ... 13を出力した後のどこかにあるもの
  9. RANGE(" ") ハードコーディング
  10. +A A. Ouputsで動作します "current_line_number+A"
  11. A+A それらが同じで、bulitin pythonタイプである限り、任意のAで機能します
  12. RANGE(1,5) ハードコーディング。
  13. FLOOR(A) Aで機能します。
  14. colors.rgb("blue")evalのlstripは、gb("blue")これをハードコード化された応答に変換します。
  15. colors.rgb("yellowish blue")evalのlstripは、引数にgb("yellowish blue")存在する場合に存在しない変数を使用しようとするyエラーを引き起こし、例外はNaNになります。
  16. colors.sort()lstripはこれをt()、ハードコーディングされた応答を持つものに変換します。

Brainsteelは、ルール10に対する私の仮定の誤りを指摘しました。


とてもきちんとした。#10では、「+ A」は単に1を
追加

ええ、それが指摘したことは明らかです。これは、intが1文字の関数として優れていることを意味します。1〜2バイト節約できます。
ダニエルウェイクフィールド

re#9:RANGE(" ")ダブルクォート文字\ x22からスペース文字\ x20までの文字の範囲です。
ジョン・ドヴォルザーク

3
再ジャンプ:ランドールが11行目に設定24れているため、2は4になり、12は14になります。これは行番号にも適用されます。
ジョンドヴォルザーク

2
インデントにスペース、タブ、タブ+スペースを使用すると、バイトを節約できます。
ティロ

16

Python、1110バイト

演算子のオーバーロードは悪ではありませんか?

from re import*
class V(str):
 def __add__(s,r):return s[:-1]+chr(ord(s[-1])+r)
class S(str):
 def __str__(s):return "'"+s+"'"if '"'in s else'"'+s+'"'
 def __repr__(s):return str(s)
 def __add__(s,r):s=str(s)[1:-1];return S('['+s+']'if type(r)==L else '"+"' if(s,r)==('','')else s+r)
class I(int):
 def __add__(s,r):return type(r)(int(s)+int(r))if s!=r else V('DONE')
 def __div__(s,r):return N if r==0 else int(s)/int(r)
 def __pos__(s):return s+c*10
 def __mul__(s,r):return V('NaN.'+'0'*13+'13')if r==1 else int(s)*int(r)
class L(list):
 def __add__(s,r):return V(str(r==s[-1]+1).upper())
def RANGE(a,b=0):return 2*(a,S(chr(ord(a)+1)))if b==0 else tuple([a]+[b-1,a+2]*((b-a)/4)+[b-1,b])
def FLOOR(n):return V('|\n|\n|\n|___%s___'%n)
def colorsrgb(c):
 m={'blue':V('#0000FF')}
 return m.get(c,N)
def colorssort():return V('rainbow')
N=V('NaN')
c=1
while True:
 try:l=raw_input('[%d] >'%c)
 except:break
 l=sub(r'(?<!"|\.)(\d+)(?!\.|\d)',r'I(\1)',l)
 l=sub(r'"(.*?)"',r'S("\1")',l)
 l=sub(r'\[(.*?)\]',r'L([\1])',l)
 l=sub(r'/\(','*(',l)
 l=sub('s\.','s',l)
 for x in str(eval(l)).split('\n'):print ' =',x
 c+=1

私の目標は、可能な限り一般的なものにすることであるので(明らかに)勝つことではありませんでした。ハードコーディングされているものはほとんどありません。以下のようなものを試してみてくださいRANGE(10)9*1RANGE("A")(2/0)+14と、"123"楽しみの結果のために!

サンプルセッションを次に示します。

ryan@DevPC-LX:~/golf/xktp$ python xktp.py
[1] >ryan@DevPC-LX:~/golf/xktp$ python xktp.py
[1] >1+1
 = DONE
[2] >2+"2"
 = "4"
[3] >"2"+2
Traceback (most recent call last):
  File "xktp.py", line 31, in <module>
    for x in str(eval(l)).split('\n'):print ' =',x
  File "<string>", line 1, in <module>
  File "xktp.py", line 7, in __add__
    def __add__(s,r):s=str(s)[1:-1];return S('['+s+']'if type(r)==L else '"+"' if(s,r)==('','')else s+r)
TypeError: cannot concatenate 'str' and 'I' objects
ryan@DevPC-LX:~/golf/xktp$ python xktp.py
[1] >ryan@DevPC-LX:~/golf/xktp$
ryan@DevPC-LX:~/golf/xktp$
ryan@DevPC-LX:~/golf/xktp$
ryan@DevPC-LX:~/golf/xktp$ python xktp.py
[1] >2+"2"
 = "4"
[2] >"2"+[]
 = "[2]"
[3] >"2"+[1, 2, 3]
 = "[2]"
[4] >(2/0)
 = NaN
[5] >(2/0)+2
 = NaP
[6] >(2/0)+14
 = Na\
[7] >""+""
 = '"+"'
[8] >[1,2,3]+2
 = FALSE
[9] >[1,2,3]+4
 = TRUE
[10] >[1,2,3,4,5,6,7]+9
 = FALSE
[11] >[1,2,3,4,5,6,7]+8
 = TRUE
[12] >2/(2-(3/2+1/2))
 = NaN.000000000000013
[13] >9*1
 = NaN.000000000000013
[14] >RANGE(" ")
 = (" ", "!", " ", "!")
[15] >RANGE("2")
 = ("2", "3", "2", "3")
[16] >RANGE(2)
Traceback (most recent call last):
  File "xktp.py", line 31, in <module>
    for x in str(eval(l)).split('\n'):print ' =',x
  File "<string>", line 1, in <module>
  File "xktp.py", line 15, in RANGE
    def RANGE(a,b=0):return 2*(a,S(chr(ord(a)+1)))if b==0 else tuple([a]+[b-1,a+2]*((b-a)/4)+[b-1,b])
TypeError: ord() expected string of length 1, but I found
ryan@DevPC-LX:~/golf/xktp$ python xktp.py
[1] >ryan@DevPC-LX:~/golf/xktp$ # oops
ryan@DevPC-LX:~/golf/xktp$ python xktp.py
[1] >RANGE("2")
 = ("2", "3", "2", "3")
[2] >RANGE(2*1)
Traceback (most recent call last):
  File "xktp.py", line 31, in <module>
    for x in str(eval(l)).split('\n'):print ' =',x
  File "<string>", line 1, in <module>
  File "xktp.py", line 15, in RANGE
    def RANGE(a,b=0):return 2*(a,S(chr(ord(a)+1)))if b==0 else tuple([a]+[b-1,a+2]*((b-a)/4)+[b-1,b])
TypeError: ord() expected a character, but string of length 19 found
ryan@DevPC-LX:~/golf/xktp$ python xktp.py # oops again
[1] >RANGE(1,20)
 = (1, 19, 3, 19, 3, 19, 3, 19, 3, 19, 20)
[2] >RANGE(1,5)
 = (1, 4, 3, 4, 5)
[3] >RANGE(10,20)
 = (10, 19, 12, 19, 12, 19, 20)
[4] >RANGE(10,200)
 = (10, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 12, 199, 200)
[5] >+2
 = 52
[6] >+"99"
Traceback (most recent call last):
  File "xktp.py", line 31, in <module>
    for x in str(eval(l)).split('\n'):print ' =',x
  File "<string>", line 1, in <module>
TypeError: bad operand type for unary +: 'S'
ryan@DevPC-LX:~/golf/xktp$ python xktp.py # oops again and again!
[1] >FLOOR(200)
 = |
 = |
 = |
 = |___200___
[2] >2+2
 = DONE
[3] >3+#
Traceback (most recent call last):
  File "xktp.py", line 31, in <module>
    for x in str(eval(l)).split('\n'):print ' =',x
  File "<string>", line 1
    I(3)+#
         ^
SyntaxError: unexpected EOF while parsing
ryan@DevPC-LX:~/golf/xktp$ python xktp.py
[1] >3+3
 = DONE
[2] >ryan@DevPC-LX:~/golf/xktp$

7

C、412バイト

これは基本的にハードコーディングされていますが、これまでの他のすべての答えには何かが欠けていました...

i;char b[99];main(){for(;;){printf("[%d]>",abs(++i));gets(b);i-=b[2]==50?26:0;printf("=>");puts(*b==82?b[6]==34?"('\"',\"!\",\" \",\"!\",'\"')":"(1,4,3,4,5)":*b==70?"|\n=>|\n=>|\n=>|___10.5___":*b==43?"12":*b==91?b[8]==50?"FALSE":"TRUE":*b==34?b[1]==34?"'\"+\"'":"\"[2]\"":*b==40?b[5]==43?"NaP":"NaN":*b==99?b[7]=='s'?"rainbow":b[12]==98?"#0000FF":"NaN":b[1]==43?b[2]==34?"\"4\"":"DONE":"NaN.000000000000013");}}

出力:

[1]>2+"2"
=>"4"
[2]>"2"+[]
=>"[2]"
[3]>(2/0)
=>NaN
[4]>(2/0)+2
=>NaP
[5]>""+""
=>'"+"'
[6]>[1,2,3]+2
=>FALSE
[7]>[1,2,3]+4
=>TRUE
[8]>2/(2-(3/2+1/2))
=>NaN.000000000000013
[9]>RANGE(" ")
=>('"',"!"," ","!",'"')
[10]>+2
=>12
[11]>2+2
=>DONE
[14]>RANGE(1,5)
=>(1,4,3,4,5)
[13]>FLOOR(10.5)
=>|
=>|
=>|
=>|___10.5___

5

Python 3、298

すべてがハードコーディングされていますが、入力は数値に変換され、文字列に変換されて、これらすべての数値とそれに続く回答を含む大きな文字列で検索されます。

B="""53"#0000FF"~62DONE~43NaN.000000000000013~25(1,4,3,4,5)~26"rainbow"~49"4"~21"[2]"~29FALSE~15|*|*|*|___10.5___~17'"+"'~1212~60('"',"!"," ","!",'"')~24NaN~31TRUE~64NaN~76NaP"""
i=0
while 1:i+=1;s=input("[%s]>"%i);print("=>"+B[B.find(str(sum(map(ord,s))%81))+2:].split("~")[0].replace("*","\n=>"))

1

Python 3、542 484バイト

絶対的なハードコーディングの言及がなかったので、ここに私の解決策があります。

a={'2+"2"':'"4"','"2"+[]':'"[2]"',"(2/0)":"NaN","(2/0)+2":"NaP",'""+""':"'\"+\"'","[1,2,3]+2":"FALSE","[1,2,3]+4":"TRUE","2/(2-(3/2+1/2))":"NaN.000000000000013",'RANGE(" ")':'(\'"\',"!"," ","!",\'"\')',"+2":"12","2+2":"DONE","RANGE(1,5)":"(1,4,3,4,5)","FLOOR(10.5)":"|\n|\n|\n|___10.5___",'colors.rgb("blue")':'"#0000FF"','colors.rgb("yellowish blue")':"NaN","colors.sort()":'"rainbow"'}
i=1
while 1:b=a[input("[%i]>"%i).replace("\t","")].split("\n");print("=> "+"\n=> ".join(b));i+=1

ハードコーディングは問題ありませんが、デフォルトで禁止されている抜け穴はデフォルトで禁止されていると思います。:P
リルトシアスト

@ThomasKwa禁止された抜け穴であるものはここにはありません。ある?
イーサンビアライン

1
すべてが私に準拠しているように見えます。以前に、「[...]標準の抜け穴について言及していない」と言ったため、抜け穴を悪用していると思いました。
リスト管理者

1
創造的だと思うが、答えではない。質問は、入力と出力について明確に語っています。「与えられたすべての入力を受け入れ、適切な出力を表示するプログラムを作成する」
-agtoever

2
両方の引用符を使用すると、かなりの量を節約できます。"2+\"2\""になり'2+"2"'ます。カウンター変数を追加すると、インポートカウントも削除される可能性があります。
ダニエルウェイクフィールド
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.