因式分解程序

// susu.cpp : Defines the entry point for the console application.
/*

因式分解程序 xmxoxo 2006-11-3 at XiaMen

*/

#include 
"stdafx.h"
#include 
"stdio.h"
#include 
"math.h"
#include 
"iostream.h"

//判断是否为素数.
bool IsSuSu(long value)
{
    
int i;
    
bool j;
    
if (value<=1)
    {
        
return 0;
    }
    
else
    {
        
if (value==2)
        {
            
return 1;
        }
        j
=0;
        
for (i=2;i<=(int)sqrt(value);i++)
        {
            
if ((value%i)==0)
            {
                j
=1;
                
break;
            }
        }
        
if (!j)
        {
            
return 1;
        }
        
else
        {
            
return 0;
        }
    }
}

// 主程式
int main(int argc, char* argv[])
{
    
int i;
    
int n;
    
int m;
    
int c;

    
while (1)
    {
        printf(
" 请输入正整数(0退出):");
        scanf(
"%d",&n);

        
if (n<=0)
        {
            
break;
        }
        m
=n;
        c
=0;
        printf(
" %d=",n);
        
for (i=2;i<=n;i++)
        {
            
if (IsSuSu(i))
            {
                
while (m%i==0)
                {
                    c
++;
                    
if (c>1)
                    {
                        printf(
"*");
                    }
                    printf(
"%d",i);
                    m
=m/i;
                }
                
if (m==1)        //提前判断是否已经结束
                {
                    
break;
                }
            }
        }
        printf(
" 共%d个因子。 ",c);
    }
    
return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值