3 回答

TA貢獻1853條經驗 獲得超6個贊
編譯時間遞歸?。篜
#include <iostream>
template<int N>
struct NumberGeneration{
static void out(std::ostream& os)
{
NumberGeneration<N-1>::out(os);
os << N << std::endl;
}
};
template<>
struct NumberGeneration<1>{
static void out(std::ostream& os)
{
os << 1 << std::endl;
}
};
int main(){
NumberGeneration<1000>::out(std::cout);
}

TA貢獻1820條經驗 獲得超3個贊
這實際上是編譯為沒有任何條件的程序集:
#include <stdio.h>
#include <stdlib.h>
void main(int j) {
printf("%d\n", j);
(&main + (&exit - &main)*(j/1000))(j+1);
}
編輯:添加了“&”,因此它將考慮地址,從而避免了指針錯誤。
標準C中的上述版本,因為它不依賴于函數指針的算術運算:
#include <stdio.h>
#include <stdlib.h>
void f(int j)
{
static void (*const ft[2])(int) = { f, exit };
printf("%d\n", j);
ft[j/1000](j + 1);
}
int main(int argc, char *argv[])
{
f(1);
}

TA貢獻1871條經驗 獲得超8個贊
#include <stdio.h>
int i = 0;
p() { printf("%d\n", ++i); }
a() { p();p();p();p();p(); }
b() { a();a();a();a();a(); }
c() { b();b();b();b();b(); }
main() { c();c();c();c();c();c();c();c(); return 0; }
我很驚訝似乎沒有人發布此消息-我認為這是最明顯的方法。 1000 = 5*5*5*8.
- 3 回答
- 0 關注
- 606 瀏覽
添加回答
舉報