高手们呵,看看这段诡异的c程序
这段c程序怎么解释可以试着编译运行
#include <stdio.h>
main(t,_,a)
char *a;
{
return!0<t?t<3?main(
-79,-13,a+main(
-87,1-_,main(
-86,0,a+1
)+a
)
):1,t<_?main(
t+1,_,a
):3,main(-94,-27+t,a)&&t==2?_<13?
main(2,_+1,"%s %d %d\n"):9:16:t<0?t<-72?main(_,t,
"@n'+,#'/*{}w+/w#cdnr/+,{}r/*de}+,/*{*+,/w{%+,/w#q#n+,/#{l+,/n{n+,/+#n+,/#\
;#q#n+,/+k#;*+,/'r :'d*'3,}{w+K w'K:'+}e#';dq#'l \
q#'+d'K#!/+k#;q#'r}eKK#}w'r}eKK{nl]'/#;#q#n'){)#}w'){){nl]'/+#n';d}rw' i;# \
){nl]!/n{n#'; r{#w'r nc{nl]'/#{l,+'K {rw' iK{;[{nl]'/w#q#n'wk nw' \
iwk{KK{nl]!/w{%'l##w#' i; :{nl]'/*{q#'ld;r'}{nlwb!/*de}'c \
;;{nl'-{}rw]'/+,}##'*}#nc,',#nw]'/+kd'+e}+;#'rdq#w! nr'/ ') }+}{rl#'{n' ')# \
}'+}##(!!/")
:t<-50?_==*a?putchar(31):main(-65,_,a+1):main((*a=='/')+t,_,a+1)
:0<t?main(2,2,"%s"):*a=='/'||main(0,main(-61,*a,
"!ek;dc i@bK'(q)-*%n+r3#l,{}:\nuwloca-O;m .vpbks,fxntdCeghiry"),a+1);
} 是宏呗! 下面这段程序,如果你能够心算出结果,你就是一个HIGHHAND啦啦啦……
main() { printf(&unix["\021%six\012\0"],(unix)["have"]+"fun"-0x60);} 我看不止是宏这么简单,它里面还包括了一种语言转换,或者加密算法的问题吧,c语言本身为了对某些国家的键盘进行支持,有一套相应的符号变换规则的。如果里面还设计到加密的话,那么这个程序可读性自然无限接近于0了。 应该是递归调用 我把它格式化后,大家就看的很清楚了。
main函数有些返回常数0或1,有些是往下的递归调用而已。 我看不止是宏这么简单,它里面还包括了一种语言转换,或者加密算法的问题吧,c语言本身为了对某些国家的键盘进行支持,有一套相应的符号变换规则的。如果里面还设计到加密的话,那么这个程序可读性自然无限接近于0了。
你可真能浅入深出啊…… 难看的懂啊 我看不止是宏这么简单,它里面还包括了一种语言转换,或者加密算法的问题吧,c语言本身为了对某些国家的键盘进行支持,有一套相应的符号变换规则的。如果里面还设计到加密的话,那么这个程序可读性自然无限接近于0了。
你真搞笑,可读性等于零有什么用?我拿到程序以后就可以直接把他编译,那有什么保密可言? 好深奥 why ioccc?
if u r the marster, would not ask such a question, otherwise, would not have time to ask.
页:
[1]