C#实现将一个正整数分解质因数

C#实现将一个正整数分解质因数

正整数分解质因数即例如:90=2✳3✳3✳5
编写代码思路:

  1. 判断输入的数据n是否为正 整数;
  2. 判断是否为1,1不是素数(质数);
  3. 判断输入数据本身是否为质数;
  4. 每次都从质数2开始查找n的因数,因此有两步:
  • 【1】 从1开始,以1为步长查找出质数i;
  • 【2】判断n%i(n对i求)是否为0,成立则输出i,并使n(新)=n(原)/i,判断n(新)是否为1,不成立则说明还有除1之外的因数,则输出乘号*;并令i=1,又从头开始查找n(新)的因数。
    代码段如下:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace norm_program
{
    class Program
    {
        static void Main(string[] args)
        {
            int i=2,k,j,n1;//n1用于判断输入的n是否为正整数;
            Console.Write("请输入一个正整数:");
            double n=double.Parse(Console.ReadLine());
            n1 =(int)n;                    
            if (n <= 0 || n - n1 != 0)
                Console.Write("数据不符合要求,请重新输入一个正整数!");
            else if (n == 1)
                Console.WriteLine("1不是质数,没有质因数!");
            else
            {
//————————————判断输入的数据本身是否为质数;——————————————————
                k = (int)Math.Sqrt(n);
                for (j = 2; j <= k; j++)
                    if (n % j == 0)
                        break;
                if (j > k)
                    Console.Write("输入的数字为质数,除其本身再没有其他质因数!");
//————————————————————————————————————————————————————————————
                else
                {
                    Console.Write("{0}的质因数表达为:{1}=",n,n);
                    for (i = 1; n != 1;i++ )
                    {
                        k = (int)Math.Sqrt(i);
                        for (j = 2; j <= k; j++)
                            if (i % j == 0)
                                break;
                        if (j > k &&(int)n %i==0&&i!=1)//i为素数,且i为n的因数;
                        {
                            Console.Write("{0}", i);
                            n = (int)n / i;
                            if(n!=1)
                                Console.Write("*"); 
                            i = 1;//使得i又从新开始遍历寻找n的质因数;
                        }
                    }
                }
            }
            Console.ReadLine();
        }
    }
}

输出结果演示:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值