区间内的真素数问题(C#)

题目:区间内的真素数

找出正整数 M 和 N 之间(N 不⼩于 M)的所有真素数。真素数的定义:如果⼀个正整数P 为素数,且其反序也为素数,那么 P 就为真素数。例如,11,13 均为真素数,因为11的反序还是为11,13 的反序为 31 也为素数。

输⼊格式:输⼊两个数 M 和 N,空格间隔,1 <= M <= N <= 100000。输出格式:按从⼩到⼤输出 M 和 N 之间(包括 M 和 N )的真素数, 逗号间隔。如果之间没有真素数,则输出 No。输⼊样例:10 35 输出样例:11,13,17,31

cs 复制代码
class Program
{
// 判断是否为素数
static bool IsSu(int number)
{
    bool isSu = true;
    for (int j = 2; j < number; j++)
    {
        if (number % j == 0)// 不是素数
        {
            isSu = false;
            //break;
            return isSu;
        }
    }
    return isSu;
}
// 反序
static int IsFanXu(int temp, int number)
{
    while (temp % 10 != 0)
    {
        number = number * 10 + temp % 10;
        temp /= 10;
    }
    return number;
}

static void Main(string[] args)
{

    string str = Console.ReadLine();// 输入有序数组
    string[] strArray = str.Split(' ');
    int[] intArray = new int[strArray.Length];
    for (int i = 0; i < strArray.Length; i++)
    {
    int num = Convert.ToInt32(strArray[i]);
    intArray[i] = num;
    }
    int m = intArray[0];
    int n = intArray[1];
    Console.WriteLine(m + "  " + n);
    for (int i = m; i < n + 1; i++)
    {
    // 判断是否为素数
    bool isSu = IsSu(i); // 调判断是否为素数的方法

    if (isSu) // 为素数
    {
    // 取反序
    int temp = i;
    int number = 0;
    number = IsFanXu(temp, number); // 调是否为反序的方法
    bool isSuFan = IsSu(number); // 调判断是否为素数的方法
    if (isSuFan)
    {
        Console.Write(i + " ");// 真素数
    }
}
}
}
}
相关推荐
唐青枫1 小时前
C#.NET 定时任务与队列利器:Hangfire 完整教程
c#·.net
hez20107 小时前
Runtime Async - 步入高性能异步时代
c#·.net·.net core·clr
mudtools21 小时前
.NET驾驭Word之力:玩转文本与格式
c#·.net
唐青枫1 天前
C#.NET 数据库开发提速秘籍:SqlSugar 实战详解
c#·.net
mudtools2 天前
.NET驾驭Word之力:理解Word对象模型核心 (Application, Document, Range)
c#·.net
大飞pkz2 天前
【设计模式】C#反射实现抽象工厂模式
设计模式·c#·抽象工厂模式·c#反射·c#反射实现抽象工厂模式
唐青枫2 天前
从入门到进阶:C#.NET Stopwatch 计时与性能测量全攻略
c#·.net
未来之窗软件服务2 天前
幽冥大陆(二)RDIFSDK 接口文档:布草洗涤厂高效运营的技术桥梁C#—东方仙盟
开发语言·c#·rdif·仙盟创梦ide·东方仙盟
1uther2 天前
Unity核心概念⑨:Screen
开发语言·游戏·unity·c#·游戏引擎
阿幸软件杂货间2 天前
Office转PDF转换器v1.0.py
开发语言·pdf·c#