Вот вспомнил студенческие годы.
Есть массив чисел r[N+1] от 0 до N требуется написать алгоритм решета
эратосфена (т.е. обнулить все составные числа) используя наименьшее
кол-во различных знаков.
После недолгих раздумий написал прогу. В алгоритме задействовано всего
9 знаков: r[f]-;=() оператор for и один раз знак "<". В принципе можно
было бы обойтись и без "<", но тогда алгоритм будет убогим, а так он
компилируется в разумную схему %).
#include<stdio.h>
#define f 99
main(){
int r[f-(-(f==f))];
for(r[f]=-(f==f);(r[f]-=-(f==f))-f;)r[r[f]]=r[f];
for(r[f-f]=r[f];--r[f-f]-(f==f);)
for(r[f==f]=r[f-f];(r[f==f]-=-r[f-f])<=f;)r[r[f==f]]=f-f;
r[f==f]=r[f-f]--;
//view output
int o;
FILE * q=fopen("q.txt","w+");
for(o=0;o<=f;o++)fprintf(q,"%d ",r[o]);
fclose(q);
};
А Вам слабо, в этом же стиле чего-нибудь написать?