创建适合XKCD类型的接口


34

colors.rgb(“ blue”)产生“#0000FF”。colors.rgb(“黄蓝色”)产生NaN。colors.sort()产生“彩虹”

使用图像中列出的规则及其标题文本(在此处引用),创建一个程序,该程序接受所有给定的输入并显示适当的输出。

  • 输入可以使用标准输入或最接近的等效输入。应该在上面[n]>键入类似的行,并且n每个命令加1。它应该从1开始。

  • 结果应使用标准输出或最接近的等效值显示。=>输出的每一行上都应该有一个。

所有13个条件,加上标题中的3个(引号)都必须有效。

这是代码高尔夫,所以最短的答案会获胜。


16
接口的通用性如何?例如,floor函数是否必须对任何提供的float起作用,或者我们是否可以假设只能通过它10.5
ankh-morpork 2015年

1
随着n的增加和输入>向右移动,输出的>与输入的>是否对齐?
Sparr

1
该漫画可能有几种解释方式。您能否提供我们需要实现哪些特定类型和操作的列表?
BrainSteel

5
为什么要n加1?那不是漫画所做的... ;-)
恢复莫妮卡

3
@WolframH它是-但他在命令11中取得了2 = 4,所以它显示14而不是12。–
Tim

Answers:


21

蟒蛇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)])

由于这使用的是一个基本的Except,因此您无法按Ctrl-C组合键。Ctrl-Z并杀死%%可以

有些条件是一般性的,而其他条件只能在确切的输入下工作。

  1. A+"B" 不仅可以在任何时候与任何A和B一起使用 A == B
  2. "A"+[] 适用于任何可以转换为int的A(包括十六进制和二进制字符串,例如0xff和0b01010)
  3. (A/0)将适用于DivideByZeroError在以下情况中处理的任何A,评估原因
  4. (A/0)+B可以与任何A或B一起使用。literal_eval(E)引发错误。
  5. ""+""仅适用于+号。其他任何内容都会打印NaN,NaP或NaN.00 ...
  6. [A, B, C]+D通过检查D == 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 适用于任何A,只要它们相同且是bulitin python类型
  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存在)导致错误,而exception变为NaN
  16. colors.sort()lstrip将其变成t()具有硬编码的响应。

Brainsteel在我对规则10的假设中指出了一个错误。


非常整洁。我认为,在#10,似乎“+ A”意在输出的行数 + A,而不只是前面加上1
BrainSteel

嗯,是的,现在已经指出了。好吧,这意味着int作为单字母函数会更好。可能节省一两个字节。
丹尼尔·韦克菲尔德

re#9:RANGE(" ")范围是从双引号\ x22到空格\ x20以及后面的所有字符。
约翰·德沃夏克

3
重新跳转:因为Randall 在第11行设置242,现在是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
lirtosiast,2015年

@ThomasKwa我在这里看不到任何被禁止的漏洞。在那儿?
伊桑·比莱恩

1
一切看起来对我来说都很合规。我早先假设您正在利用漏洞,因为您说“没有提到标准漏洞”。
lirtosiast 2015年

1
我认为这是有创意的,但不是答案。这个问题清楚地谈到了输入和输出:“创建一个接受所有给定输入并显示适当输出的程序”
大约

2
通过使用两个引号,可以节省大量费用。"2+\"2\""成为'2+"2"'。如果添加计数器变量,也可以删除导入计数。
丹尼尔·韦克菲尔德
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.