鱼C论坛

 找回密码
 立即注册
查看: 950|回复: 3

[已解决]7-3 最小回文素数

[复制链接]
发表于 2022-3-19 17:14:26 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 学鸣 于 2022-3-19 17:14 编辑

求大佬们帮个忙
大一刚学,自己想了半天,输入格式不会搞,请各位解一下题,能完整解答更好
QQ截图20220319170709.png
最佳答案
2022-3-19 17:32:10
#include <stdio.h>

int is_prime(int x)
{
    for (int i = 2; i < x / 2; i++)
    {
        if (x % i == 0)
        {
            return 0;
        }
    }
    return 1;
}

int is_palindromes(int x)
{
    int m = 0, s = 0, n;

    s = x;
    while (s != 0)
    {
        n = s % 10;
        m = m * 10 + n;
        s = s / 10;
    }

    return x == m;
}

int main()
{
    int T;

    scanf("%d", &T);

    int array[T];
    int result[T];

    for (int i = 0; i < T; i++)
    {
        scanf("%d", &array[i]);

        if (array[i] > 65535)
        {
            printf("ERROR");
            return 0;
        }

        int j = 0;
        while (!is_prime(array[i] + j) || !is_palindromes(array[i] + j))
        {
            j++;
        }
        result[i] = array[i] + j;
    }

    for (int i = 0; i < T; i++)
    {
        printf("%d\n", result[i]);
    }

    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-3-19 17:32:10 | 显示全部楼层    本楼为最佳答案   

回帖奖励 +20 鱼币

#include <stdio.h>

int is_prime(int x)
{
    for (int i = 2; i < x / 2; i++)
    {
        if (x % i == 0)
        {
            return 0;
        }
    }
    return 1;
}

int is_palindromes(int x)
{
    int m = 0, s = 0, n;

    s = x;
    while (s != 0)
    {
        n = s % 10;
        m = m * 10 + n;
        s = s / 10;
    }

    return x == m;
}

int main()
{
    int T;

    scanf("%d", &T);

    int array[T];
    int result[T];

    for (int i = 0; i < T; i++)
    {
        scanf("%d", &array[i]);

        if (array[i] > 65535)
        {
            printf("ERROR");
            return 0;
        }

        int j = 0;
        while (!is_prime(array[i] + j) || !is_palindromes(array[i] + j))
        {
            j++;
        }
        result[i] = array[i] + j;
    }

    for (int i = 0; i < T; i++)
    {
        printf("%d\n", result[i]);
    }

    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2022-3-19 17:59:14 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-19 20:11:07 | 显示全部楼层

回帖奖励 +20 鱼币

本帖最后由 jhq999 于 2022-3-19 22:15 编辑
int outmin(int innum)
{
        innum++;
        int len=0,num=innum,i=0;
        while (num)len++,num/=10;
        int *fj=new int[len];
        num=innum;
        for (i=0;i<len;i++)
        {
                fj[len-1-i]=num%10;
                num/=10;
        }
        a=len/2+len%2;
        for (i = 0; i < len/2; i++)
        {
                        
                         if(fj[len/2-i-1]<fj[a+i])
                        {
                                fj[a-1]++;
                                break;
                        }
        }
        
        for (i = 0; i < len/2; i++)fj[len-i-1]=fj[i];
        for (i = 0,num=0; i < len; i++)num=num*10+fj[i];
        delete[] fj;
        return num;
}
int main()
{
        int n=0,*innum=NULL,i=0;
        scanf("%d",&n);
        innum=new int[n];
        for (i = 0; i < n; i++)
        {
                scanf("%d",innum+i);
                innum[i]=outmin(innum[i]);
                
        }
        for (i = 0; i < n; i++)
        {
                printf("%d\n",innum[i]);
        }
        delete[] innum;
        return 0;

}
#include <stdio.h>
#include <stdlib.h>
int outmin(int innum)
{
        innum++;
        int len=0,num=innum,a=0,b=0,c=0,i=0;
        while (num)len++,num/=10;

        num=innum;
        b=1;
        for (i=0;i<len/2;i++)
        {

                num/=10;
                b*=10;
        }
        c=b;
        b=innum-num*b;
        innum=len%2?num/10:num;
        a=0;
        for (i=0;i<len/2;i++)
        {
                a=a*10+innum%10;
                innum/=10;
        }
        if (b>a)
        {
                num++;
        }
        
        num=num*c+a;
        return num;
}
int main()
{
        int n=0,*innum=NULL,i=0;
        scanf("%d",&n);
        innum=new int[n];
        for (i = 0; i < n; i++)
        {
                scanf("%d",innum+i);
                innum[i]=outmin(innum[i]);
                
        }
        for (i = 0; i < n; i++)
        {
                printf("%d\n",innum[i]);
        }
        delete[] innum;
        return 0;

}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-18 06:26

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表