| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 566 人关注过本帖
标题:将正数n分解质因数并输出的操作
只看楼主 加入收藏
张学平
Rank: 2
等 级:论坛游民
帖 子:26
专家分:13
注 册:2013-11-20
结帖率:75%
收藏
已结贴  问题点数:20 回复次数:3 
将正数n分解质因数并输出的操作
我用的是指针,但是结果不尽人意
程序代码:
#include <stdio.h>
int t;
int *p(int m)
{int i,j,a[400],f,*pt;

 a[0]=2;a[1]=3;t=2;

 for(i=4;i*i<=m;i++)
  {f=1;
      for(j=2;j*j<=i;j++)
       if(i%j==0)f=0;
   if(f){a[t]=i;t++;}
  }//problem
 pt=a;

 return pt;
}
int main(void)
{int *q,b[200],n,m,i,l;

 l=0;

 printf("Please input the integer n:\n");

 scanf("%d",&n);m=n;

 q=p(n);

 i=0;while(i<=t){printf("%d ",*(q+i));i++;}i=0;

 while(n!=1)

 {if(n%(*(q+i))==0){b[l]=*(q+i);l++;n=n/(*(q+i));i=0;continue;}

 i++;}

 printf("%d=",m);

 for(i=0;i<=l;i++)
  printf("%d ",b[i]);
}

搜索更多相关主题的帖子: 质因数 
2013-12-02 21:20
好男儿!
Rank: 2
来 自:陕西省
等 级:论坛游民
帖 子:29
专家分:52
注 册:2013-7-26
收藏
得分:5 
太繁琐了,不用指针就可以。

#include<stdio.h>
#include<conio.h>

void main(void)
{
    int i;
    int n;
    printf("请输入一个数:");
    scanf("%d",&n);

    printf("%d = ",n);
    for(i=2; i<=n; i++)
    {

        while(n%i == 0)
        {
            n /= i;
               
            n == 1? printf("%d", i) : printf("%d*",i) ;
        }
    }
   
    getch();
}
2013-12-02 22:47
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:15 
回复 2楼 好男儿!
一个循环就行了
程序代码:
#include <stdio.h>

int main(void)
{
    unsigned n;
    printf( "请输入一个数:" );
    scanf( "%d", &n );

    // 分解质因数
    {
        unsigned i;
        printf("%d = ",n);
        for( i=2; i<=n; )
        {
            if( n%i == 0 )
            {
                n /= i;
                printf( "%d%c", i, "*\n"[n==1] );
            }
            else
                ++i;
        }
    }

    return 0;
}

2013-12-03 08:32
好男儿!
Rank: 2
来 自:陕西省
等 级:论坛游民
帖 子:29
专家分:52
注 册:2013-7-26
收藏
得分:0 
回复 3楼 rjsp
受教了。谢谢
2013-12-03 13:10
快速回复:将正数n分解质因数并输出的操作
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.040710 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved