这个128种语言的quine ouroboros (以另一种语言输出程序,以另一种语言输出程序,(125种语言后)输出原始程序)相当令人印象深刻。但不幸的是,它有一个静态的迭代次数。
编写一个程序,它输出一个程序(不一定用另一种语言,但可以是),它输出一个程序,输出一个程序,等等,在n次迭代后,第一次输出原始程序(也就是说,中间程序不应该和原始程序相同,否则忽略它的输入的quine就能工作),其中n是作为输入提供的非负整数。输入不能仅仅是原始源代码中的一个数字(例如,将x = <the value of n>放在程序的开头),它应该是以下内容之一:
对于ouroboros的中间阶段,您的程序可以是一个功能齐全的程序,也可以是一个没有参数的函数,当调用它时,它将返回/输出下一个程序。
您可能不会从源文件本身读取,也不会使用任何类似quine的内置程序(我不认为有这样的方法,但可能存在)。
要明确的是,如果是n = 0,程序应该输出自己的源代码。
如果是n = 1,程序应该输出一个不同的程序,该程序输出原始源代码。
等等..。
最少字节赢!
我应该写到“对于ouroboros的中间阶段,您的程序可以是一个没有输入的功能完整的程序,也可以是一个没有参数的函数”。如果您的程序输出链中的下一个,则等待输入,这很好,但是您的程序不应该需要原始值n。
发布于 2019-07-03 12:56:36
发布于 2019-07-03 19:48:46
发布于 2019-07-03 14:12:08
void f(int n=-1){var s="void f(int n={2}){{var s={0}{1}{0};Write(s,(char)34,s,n-1);}}";Write(s,(char)34,s,n-1);}多亏@NickKennedy,节省了很多字节!
https://codegolf.stackexchange.com/questions/187627
复制相似问题