palin.c

来自「比较新的功能强大的rsa算法源代码,方便使用.」· C语言 代码 · 共 54 行

C
54
字号
/*
 *   Program to investigate palindromic reversals.
 *   Gruenberger F. Computer Recreations, Scientific American. April 1984.
 *
 *   Copyright (c) 1988-1997 Shamus Software Ltd.
 */

#include <stdio.h>
#include "miracl.h"

BOOL rever(big x,big y)
{ /* reverse digits of x into y       *
   * returns TRUE if x is palindromic */
    int m,n;
    int i,k,swaps;
    BOOL palin;
    copy(x,y);
    palin=TRUE;
    k=numdig(y)+1;
    swaps=k/2;
    for (i=1;i<=swaps;i++)
    {
        k--;
        m=getdig(y,k);
        n=getdig(y,i);
        if (m!=n) palin=FALSE;
        putdig(m,y,i);
        putdig(n,y,k);
    }
    return palin;
}

int main()
{  /*  palindromic reversals  */
    int iter;
    big x,y;
    mirsys(120,10);
    x=mirvar(0);
    y=mirvar(0);
    printf("palindromic reversals program\n");
    printf("input number\n");
    innum(x,stdin);
    iter=0;
    while (!rever(x,y))
    {
        iter++;
        add(x,y,x);
        otnum(x,stdout);
    }
    printf("palindromic after %d iterations\n",iter);
    return 0;
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?