c:计算合数的质因数,并输出为n=axbxcxd
来源:互联网 发布:python与weka的区别 编辑:程序博客网 时间:2024/06/15 10:23
每个非素数(合数)都可以写成几个素数(也可称为质数)相乘的形式,这几个素数就都叫做这个合数的质因数。比如,6可以被分解为2x3,而24可以被分解为2x2x2x3。
现在,你的程序要读入一个[2,100000]范围内的整数,然后输出它的质因数分解式;当读到的就是素数时,输出它本身。
输出格式:n=axbxcxd
#include <stdio.h>#include <stdlib.h>#include <string.h>/*每个非素数(合数)都可以写成几个素数(也可称为质数)相乘的形式,这几个素数就都叫做这个合数的质因数。比如,6可以被分解为2x3,而24可以被分解为2x2x2x3。现在,你的程序要读入一个[2,100000]范围内的整数,然后输出它的质因数分解式;当读到的就是素数时,输出它本身。输出格式: n=axbxcxd*/int isPrime(int num);int primeNumber(int num,int* ret);void showPirmeNumber(int num,int* numArr,int count);int main(int argc, char const *argv[]){ int input = -1; if(input< 2){ printf("%s\n","输入不合法,程序异常退出!"); return 0; } int* ret = (int*)malloc(50*sizeof(int*)); int count = primeNumber(input,ret); showPirmeNumber(input,ret,count); free(ret); return 0;}int isPrime(int num){ int prime = 1; if (num<2){ prime = 0; } for (int i = 2; i < num; ++i) { if(num%i==0){ prime = 0; break; } } return prime;}int primeNumber(int num,int* ret){ // 12=2*2*3 --> 2*6 --> 2*2*3 // 24=2*12 --> const int N = 50; int count = 1; while(isPrime(num)==0){ for (int i = 2; i < num; ++i) { //printf(" i =%d , num = %d\n", i, num); if(num %i ==0){ *ret++ = i; num /=i; count +=1; break; } } } *ret++ = num; // printf("sss = %d\n",count); return count;}void showPirmeNumber(int num,int* numArr,int count){ // 12=2*2*3 const int decimal = 10; char* n = (char*)malloc(100*sizeof(char*)); itoa(num,n,decimal); strcat(n,"="); for (int i = 0; i < count; ++i) { char t[5]; itoa(numArr[i],t,decimal); strcat(n,t); if(i!=count-1){ strcat(n,"x"); } } printf("%s\n", n); free(n);}
输出如下:
100000=2x2x2x2x2x5x5x5x5x5[Finished in 2.0s]
- 难点1:如何将一个数字转换为字符串,比如
1234
->"1234"?
- 使用
itoa()
函数即可传送门:itoa百度百科
- 使用
- 难点2:如何获取一个数字的所有质因数:如:12 = 2*2*3 这样。
- 参考
primeNumber()
函数。 - 私以为
primeNumber()
有点低效之嫌…
- 参考
彩蛋时刻:由于itoa()
是非标准c函数库里面的函数,所以,将该函数实现一下放这里了。(然而并不是我实现的,出自传送门:itoa百度百科)
- 既然百科上面已经有了,干嘛还抄过来呢?
- 只能说百度百科对code格式还是不够友好。如果直接复制到编译器会直接编译失败,还是需要调整一下格式的。于是,为了以后的重用,我就把这个函数调整好格式,测试ok之后,直接拿过来了。~
char* itoa(int num,char*str,int radix){ /*索引表*/ char index[]="0123456789ABCDEF"; unsigned unum;/*中间变量*/ int i=0,j,k; /*确定unum的值*/ if(radix==10&&num<0) { /*十进制负数*/ unum=(unsigned)-num; str[i++]='-'; } else unum=(unsigned)num; /*其他情况*/ /*转换*/ do { str[i++]=index[unum%(unsigned)radix]; unum/=radix; } while(unum); str[i]='\0'; /*逆序*/ if(str[0]=='-'){ k=1;/*十进制负数*/ } else{ k=0; } char temp; for(j=k; j<=(i-1)/2; j++) { temp=str[j]; str[j]=str[i-1+k-j]; str[i-1+k-j]=temp; } return str;}
0 0
- c:计算合数的质因数,并输出为n=axbxcxd
- Java-求合数的质因数
- 合数的质因数分解 + 递归求等比数列前n项和
- 项目39.2求满足条件n=a!+b!+c!的所有三位数n并输出,其中a,b,c分别为n的百、十、个位数。
- 计算并输出n!=1*2*3*...*n
- 判断质因数的个数并依次输出
- 把一个合数分解为几个质因数相乘
- 计算并输出1+2+...+n的值
- 计算并输出1+2+3+..............+n的值
- 计算并输出1+2+3+......+n的值
- 计算并输出1+2+3+...+n的值
- C语言实现 N!的质因数分解
- 题解:求满足条件n=a!+b!+c!的所有三位数n并输出
- 计算合数
- 分解质因数并输出详解
- 输入一个整数n, 计算1到n的和并以16进制输出
- 3.3 设银行定期存款的年利率rate为2.25%,已知存款期为n年,存款本金为capital元,试编程计算并输出n年后的本利之和deposit
- 100以内的质因数分解并计算完全平方数
- 《Objective-C编程全解》 读书笔记 第二十章 键值编码
- 划分无冲突子集
- [机房练习赛4.3][poj1988]bricks
- Hibernate中实体映射时的命名策略(2)
- 微服务架构(六): API Gateway
- c:计算合数的质因数,并输出为n=axbxcxd
- myeclipse+maven实现多模块项目struts+spring+mybatis
- JAVA进阶学习-反射机制
- Linux目录
- Leetcode-94. Binary Tree Inorder Traversal
- Eclipse的使用总结
- RDDs 特性
- Eclipse启动GC日志
- Centos6.5编译安装php7.1.3