#include #define decprec 78 #define b1prec 127 #define b2prec 256 /* b2prec should be b1prec*2+2 */ void main(int argc, char *argv[]) { int i, j, k, l; int d[decprec]; int b1[b1prec]; int b2[b2prec]; int bn[b2prec][decprec]; int lp1[b2prec]; /* Initializations */ printf("\nInitializing...\n"); l=-1; for (i=0; il) { l++; } for (j=0; j-1; i-=1) { b2[j]=b1[i]; j++; } for (i=0; i<=l; i++) { b2[j]=b1[i]; j++; } /* j is now the length+1 of b2. (b2[0..j-1]) */ /* Convert b2 to decimal d */ for (i=0; i-1; j-=1) { printf("%d", b2[j]); } i-=1; printf(" "); for (j=i; j>-1; j-=1) { printf("%d", d[j]); } printf("\n"); } /* Create b2 binary palindrome #2. */ j=0; for (i=l; i>-1; i-=1) { b2[j]=b1[i]; j++; } b2[j]=0; j++; for (i=0; i<=l; i++) { b2[j]=b1[i]; j++; } /* j is now the length+1 of b2. (b2[0..j-1]) */ /* Convert b2 to decimal d */ for (i=0; i-1; j-=1) { printf("%d", b2[j]); } i-=1; printf(" "); for (j=i; j>-1; j-=1) { printf("%d", d[j]); } printf("\n"); } /* Create b2 binary palindrome #3. */ j=0; for (i=l; i>-1; i-=1) { b2[j]=b1[i]; j++; } b2[j]=1; j++; for (i=0; i<=l; i++) { b2[j]=b1[i]; j++; } /* j is now the length+1 of b2. (b2[0..j-1]) */ /* Convert b2 to decimal d */ for (i=0; i-1; j-=1) { printf("%d", b2[j]); } i-=1; printf(" "); for (j=i; j>-1; j-=1) { printf("%d", d[j]); } printf("\n"); } } /* End of while (1) loop */ }