整数因子分解问题 include<;stdio.h>;int count=0;void derive(int a)/采用递归方法得到所要的数值{ int i;for(i=a;i>;1;i-)if((a%i)=0){ count+;derive(a/i);} } main(){ int num;char c;while。
c语言分解正整数因子,输入不是以2为因子的结果不正确,感觉问题应该出现在主函数循环部门 先说这里有个问题:int zhishu(int a){int i=2,flag;for;i(a);i+){if(a%i=0){/这里要加一对括号,保证作用域flag=1;break;}/这里要加一对括号}if(i>;sqrt(a))flag=0;return(flag);}不知道这样是否达到你要的效果。
C++算法整数因子分解问题 #includelong total=0;int main(){void solve(long n);函数声明,防止编译出错long n;cin>;>;n;从键盘输入一个整数solve(n);cout;输出因子数量return 0;}void solve(long n){if(n=1)total+;如果n等于1,则总数total加1else {for(long i=2;i;i+)/从2到n循环if(n%i=0)/如果i能整除n,则以n/i为参数递归调用函数solvesolve(n/i);}}这段程序,是通过递归调用solve统计n的质因子数量,凡是solve参数=1,则前一次调用n时,整除n的因子i=n,此时i必为一个质因子。通过统计solve的参数为1的数量,来间接统计n的质因子数量