【c语言】--分解质因数【完整版详细】

这篇具有很好参考价值的文章主要介绍了【c语言】--分解质因数【完整版详细】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、质因数是什么?

首先,我们所说的质数就是素数,两种叫法都可以!
如果一个数的因数是质数,那么这个因数就是他的质因数。
比如:
5的因数:1、5 因数5就是5的质因数。
28的因数:4、7 因数7就是28的质因数。

2、什么是分解质因数?

把一个合数用质数相乘的形式表示出来,叫作分解质因数。他强调的是分解的过程
1、合数可以分解质因数,质数不能分解质因数,因为质数只能等于1*本身这种形式,而1不是质数。
2、分解质因数不是一个具体的数,而是把一个合数分解为成几个质数相乘的过程

3、怎么分解质因数?

不妨我们先引入一道编程题

题目:输入你要分解质因数的数的范围,输出每个数分解质因数的因数 输入样例 : 3 10 输出样例: 3=3 4=2 * 2 5=5 6=2 * 3 7=7 8=2 * 2 * 2 9=3 * 3 10=2 * 5

分解质因数的过程

1、我们先以8为例

我们先以最小的质数2开始试
8/2=4此时是不是还能除以2,那么再4/2=2 此时最后2为质数了,这就成为了终止条件,所以8 = 2 * 2 * 2
2、我们再以9为例

还是从2开始试
9/2 无法整除,那么2加1=3,判断3为素数,所以有可能是9的质因数,9/3=3,此时3为质数了,这成为了终止条件所以9 = 3 * 3
2、我们再以10为例

还是从2开始试
10/2=5,5直接为质数,直接达到终止条件,所以10 = 2 * 5
总结:
从2开始作为因子,能整除就一直除,直到最后的结果为质数再终止,那么结果就等于{你要分解的数=之前被除的因子*最后的终止条件(质数)
如果2不能整除了,就往上+1,然后还要判断被+1的数是否为质数,只有他是质数才有作为质因子的必要!然后再让你要分解的数除以这个因子,看是否能整除,不能整除就+1

最后代码如下,详细讲解均在代码块里面!按理来说,质数的分解不算分解质因数过程,但下列代码包括质数的分解,不要产生误解!

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<math.h>
int isprime(int n)
{
	int flag = 1;
	int i = 0;
	for (i = 2; i <= sqrt(n); i++)//别忘了sqrt要引头文件math.h
	{
		if (n % i == 0)
		{
			flag = 0;
			break;
		}
	}
	return flag;
		
}
int main()
{
	//1、用min和max变量确定你要求质因数的数的范围
	//比如输入3 10 就会帮助你求3-10这每个数所能分解的质因数
	int min = 0;
	int max = 0;
	int i = 0;
	int j = 0;
	printf("请输入你想获得质因数的数的范围\n");
	scanf("%d %d", &min, &max);
	//2、写一个判断是否为素数的函数isprime()
	//如果是素数直接写出该素数=该素数
	//如果判断为合数,就要用合数分解质因数的方法。
	for (i = min; i <= max; i++)
	{
		if (isprime(i))
		{//为真则为质数,直接输出
			printf("%d=%d\n", i, i);
		}
		else
		{
	    //既然进了else就说明是合数了
			int tmp = i;//tmp为临时保存i的值,防止i在后面的操作中被改变
			printf("%d=", tmp);
			for (j = 2; j < tmp; j++)
			{//这里j从二开始,因为我此时分解合数,最小的质数是2,所以从2开始
			 //还应注意的是必须是j<tmp,如果多一个=,那还分解什么合数,直接等于本身*1了
				if (isprime(j))
				{//判断是否为质数,因为分解质因数的前提是因子必须为质数的前提下
					while (tmp % j == 0)
					{
						printf("%d*", j);
						tmp /= j;
						if (isprime(tmp))
						{//一直除以质因子,直到有一次除出来结果是质数,说明分解质因数完毕
							printf("%d", tmp);
							break;
						}
					}

				}
			}
			printf("\n");
		}
	}
	return 0;

}

c语言分解质因数,【c语言】经典代码题,c语言,算法文章来源地址https://www.toymoban.com/news/detail-735458.html

到了这里,关于【c语言】--分解质因数【完整版详细】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 洛谷B2084质因数分解

    已知正整数 n 是两个不同的质数的乘积,试求出较大的那个质数。 输入只有一行,包含一个正整数 n(6n1000000000)。 输出只有一行,包含一个正整数 p,即较大的那个质数。 输入 #1 输出 #1

    2024年02月22日
    浏览(35)
  • 洛谷——P1069 [NOIP2009 普及组] 细胞分裂(分解质因数,唯一分解定理)

    Hanks 博士是 BT(Bio-Tech,生物技术)领域的知名专家。现在,他正在为一个细胞实验做准备工作:培养细胞样本。 Hanks 博士手里现在有 N N N 种细胞,编号从 1 ∼ N 1 sim N 1 ∼ N ,一个第 i i i 种细胞经过 1 1 1 秒钟可以分裂为 S i S_i S i ​ 个同种细胞( S i S_i S i ​ 为正整数)。

    2024年01月16日
    浏览(46)
  • Python中查找质因数

    如何在Python中进行素因式分解。 在数学中,一个数的因数是指那些可以除以给定数并留下零余数的数字。 质数是只有两个因数的独特数字,一个和数字本身。这类数字的一些例子是3,7,11,13,等等。 素数因数化是指找到所有乘以原数的素数。我们可以考虑一个简单的例子:数字

    2024年02月10日
    浏览(43)
  • 试题 C: 质因数个数

    萎了,整个人都萎了 快三天都没刷题了,想着明天就蓝桥杯了,就找了个真题做了下 可以看得出来这题很简单 但是没有测试点给我用,所以我的代码不保证正确性 代码如下:

    2024年04月13日
    浏览(34)
  • 质因数算法(C/C++)

    目录 1  分解质因数 2  打印质数表 2.1  O(n^2)算法(暴力法) 2.2  O(nlogn)算法(埃氏筛) 2.3  O(n)算法(线性筛) 3  计算因数和 说明:这里不需要担心没有筛选质数的问题,因为是从小到大循环,不可能存在分解出合数的情况(例如:2第一个循环,所有2的倍数都已

    2023年04月09日
    浏览(35)
  • 蓝桥杯双周赛算法心得——铺地板(质因数)

    大家好,我是晴天学长,这是第二周的蓝桥杯的双周赛,题可出的又好又灵活啊!真不错!💪💪💪 1) .铺地板 2) .算法思路 1.导入java.util包中的Scanner类,以从用户那里读取输入。 2.main方法是程序的入口点。 3.创建一个Scanner对象,用于从标准输入读取输入。 4.从用户那里读取

    2024年02月08日
    浏览(39)
  • [保研/考研机试] KY7 质因数的个数 清华大学复试上机题 C++实现

    求正整数N(N1)的质因数的个数。 相同的质因数需要重复计算。如120=2*2*2*3*5,共有5个质因数。 输入描述: 可能有多组测试数据,每组测试数据的输入是一个正整数N,(1N10^9)。 输出描述: 对于每组数据,输出N的质因数的个数。 输入: 输出: 只需要判断因数是否能够整除当前

    2024年02月13日
    浏览(45)
  • C. Multiplicity(DP + 分解因数)

    Problem - C - Codeforces 给定一个整数数组a1,a2,...,an。 如果可以从a中删除一些元素得到b,则称数组b为a的子序列。 当且仅当对于每个i(1≤i≤k),bi是i的倍数时,数组b1,b2,...,bk被称为好。 在模109+7下找到a中好的子序列的数量。 如果两个子序列的包含数字的索引集合不同

    2024年02月02日
    浏览(30)
  • Python使用递归法对整数进行因数分解

    所谓因数分解,是指把一个整数变成其所有质因数相乘的形式,例如10=2*5, 39000=2*2*2*3*5*5*5*13。 from random import randint def factors(num, fac=[]):     #每次都从2开始查找因数     for i in range(2, int(num**0.5)+1):         #找到一个因数         if num%i == 0:             fac.append(i)        

    2023年04月23日
    浏览(36)
  • C语言必背经典程序代码

    题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数   本身。例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。 使用函数封装,实现一个整型数组内数据的求和。 斐波那契数列(Fibonacci sequence),又称

    2023年04月20日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包