int i;main(){for(;i["]<i;++i){--i;}"];read('-'-'-',/
i+++"hello, world!/n",'/'/'/'));}read(j,i,p){write/
(j/p+p,i---j,i/i);}
[原创文章,转载请保持文章完整,并注明出处。更多精彩文章请访问http://blog.csdn.net/Jupin 或者 http://hi.baidu.com/qiupingwu]
这是1984年模糊C语言大赛的一个程序,整理一下格式:
int i;
main()
{
for
(
;
i["]<i;++i){--i;}"];
read
(
'-'-'-',
i++ + "hello, world!/n",
'/'/'/'
)
);
}
read(j, i, p)
{
write(j/p+p, i-- -j, i/i);
}
可以看出这是由一个子函数加一个主函数组成的。根据C语言的默认
规则, i初始值为零。
main函数中只有一个空循环语句,先来分析一下这个循环语句。
i["]<i;++i){--i;}"];
下标是一个字符串常量,其值为指向这个字符串第一个字母的指针,
假设为P,则该句等价于
i[P]
表示以i为基址,偏移P处的内容,当然这可以等价于以P为基址,
偏移i处的内容,即又可表示为
P[i]
因此这个循环判断语句的实际语义是从左至右依次取出字符串常
量中的字符,当取到字符串的最后字符时,返回0,从而起到控制循
环次数的作用--次数为字符串的长度。
循环的实际操作放在如下语句完成:
read
(
'-'-'-',
i++ + "hello, world!/n",
'/'/'/'
)
显然,read函数的第一、三个参数是固定的,分别为0和1,第
二个参数在各次循环执行时分别传入指向"hello, world!/n"常
量字符串的各个字符的指针的值加1。
在read函数中执行系统调用write完成内容输出。根据对
main的函数的分析,可以得到传给write的参数为(0, p, 1);
其中p为指向字符的指针。由write系统调用的参数意义,0表示
标准输出,1表示每次写入长度为1,因此它在这里的每次调用均
输出"hello, world!/n"中的一个字符,直至字符串结束。
3.141592653589793238462643383279