㈠ 分解質因數的c語言怎麼寫
#include<stdio.h>
voidmain()
{
inti=2,n,k;
printf("輸入不小於2的自然數:");
scanf("%d",&n);
k=n;
printf("%d=",n);
while(k>1)
{
if(k%i==0){printf("%d*",i);k/=i;}
elsei++;
}
printf("");
}
㈡ c語言質因數分解;
#include<stdio.h>
main()
{inttemp,n,i1,m;
intdata,j,i;
inta[100],b[100];
m=1;
j1=1;
while(scanf("%d",&data)!=EOF)
{j=0;i=2;
while(data>1)
{if(data%i==0)
{a[j]=i;
j=j+1;
data/=i;
}
elsei++;
}
n=j-1;
for(i=0;i<n;i++)
{i1=1;
for(j=i+1;j<=n;j++)
{if(a[i]==a[j])
i1=i1+1;
elsebreak;
}
if(i1!=1)
{printf("%d^%d",a[i],i1);
}
else
printf("%d",a[i]);
i=i+i1-1;
if(a[i]!=a[n])
printf("*");
}
if(a[n]!=a[n-1]||n==0)
printf("%d",a[n]);
printf(" ");
j1=j1+1;
}
}
這段代碼是在你寫的代碼基礎上改的,首先不需要對a數組重新排序,因為求出的a數組原本就是一組從大到小的數組,i=2要放在while循環裡面,每次重新輸入數值重置i的值,
不能用i<n來判斷是否該輸出最後*,在循環里i的值會一直小於n,因為前面for循環里已經定義了在i<n的情況下進行循環,還有在最後應該考慮數組只有一個數的情況
㈢ c語言質因數分解題目怎麼做
#include<stdio.h>
#include<math.h>
int main() {
long long n,i,j,k;
while(~scanf("%ld",&n)) {
k=1;
for(i=2; i<=sqrt(n); i++) {
j=0;
if(n%i==0) {
if(k)k=0;
else printf("*");
printf("%ld",i);
while(n%i==0) {
j++;
n/=i;
}
if(j>1)printf("^%ld",j);
}
}
if(n>1)
if(k)printf("%ld",n);
else printf("*%ld",n);
printf("\n");
}
return 0;
}
㈣ 求助c語言編程題目質因數分解
因為使用for循環從小到大判斷其因數,而質數在由其組成的合數前面,所以如果i是n的因數,那麼i一定是質因數,而且質因數會從小到大輸出.
具體編程時,我們還應該使用n=n/i;,使for循環能快速滿足終止條件,節省運行時間.用i--;,處理有多個重復質因數的情況.用count來統計相同質因數的個數.
具體的解釋見注釋
#include<stdio.h>
int main(){
//n輸入的要分解的數,m前一個質因數,i循環變數
//flag第一個輸出的質因數的標志變數,count統計有幾個相同的質因數
int n,m,i,flag,count;
while(scanf("%d",&n)==1){//輸入一個數n,直到一次輸入的參數個數不等於1
flag=1;//第一次輸出的質因數的標志為1
m=0;//前一個質因數賦初值為0
count=1;//相同質因數個數為1
for(i=2;i<=n;i++){ //for循環從2到n
if(n%i==0){//如果n能被i整除,則i為質因數
if(m==i){//如果質因數與前一個質因數相同
count++;//相同質因數個數加一
}else{//如果質因數與前一個質因數不同
if(flag==1){//如果是第一次輸出
printf("%d",i);//輸出第一個質因數
flag=0;//把標志變數置0,後面輸出的質因數都不是第一個了
}else{//不是第一次輸出
if(count==1){//有一個不相同的質因數輸出
printf("*%d",i);//輸出不相同的質因數
}else{//有多個相同的質因數輸出
printf("^%d",count);//輸出相同的質因數個數
count=1;//重置相同質因數個數為1
printf("*%d",i);//輸出新的不同的質因數
}
}
}
m=i;//把當前質因數賦給存儲前一個質因數的變數m
n=n/i;//改變循環范圍n為n/i後的值
i--;//i減一,以處理有多個相同質因數的情況
}
}
if(count>1) printf("^%d",count);//如果有多個相同質因數,輸出其個數
printf(" ");//換行
}
return 0;
}
㈤ C語言分解質因數怎樣編輯
#include <stdio.h>
int main(){
int n; // 用戶輸入的整數
int i; // 循環標志
printf("輸入一個整數:");
scanf("%d",&n);
printf("%d=",n);
// n>=2才執行下面的循環
for(i=2; i<=n; i++){
while(n!=i){
if(n%i==0){
printf("%d*",i);
n=n/i;
}else
break;
}
}
printf("%d ",n);
return 0;
}
㈥ c語言 分解質因數
#include"stdio.h"
intmain()
{
intn;
inti,j,a;
a=0;
do
{
scanf("%d",&n);
a+=1;
if(n>0)
printf("Case%d: ",a);
i=2;
while(n>=i)
{
if(n%i==0)
{
j=0;
printf("%d",i);
while(n%i==0)
{
n=n/i;
j+=1;
}
printf("%d ",j);
}
i+=1;
}
}while(n>0);
}
㈦ C語言求合數的質因數分解,並輸出出現最多的質因數
這個程序寫得太過復雜了,完全可以簡單一點的。具體的演算法是從2開始嘗試找出給你寫的數所有的質因數,並統計每一個質因數出現的次數。分別保存在兩個數組中。
等到全部分解完成後,再檢查其中出現次數最多的,進行輸出就可以了。
下面是我的程序和運行結果:
#include <stdio.h>
int main()
{ int i,j,k=0,n,a[50],b[50]= {0};
scanf("%d",&n);
for(i=2; i*i<=n; i++)
{ for(j=1; n%i==0; n/=i)
{ if(j)
{ a[k]=i;
b[k]=1;
j=0;
}
else b[k]++;
}
if(!j)k++;
}
if(n>1)
{ a[k]=n;
b[k++]=1;
}
for(i=1,j=0; i<k; i++)
if(b[i]>=b[j])j=i;
printf("%d
",a[j]);
return 0;
}
㈧ C語言,分解質因數
你的代碼有兩處錯誤或不完善的地方,以下是我對你的代碼的修改:
#include<stdio.h>
int main(){
int n,i;
scanf("%d",&n);
for(i=2;i<=n;i++){//將2000換成n,也就是被除數,除數比被除數大,除來也就沒有意義了
if(n%i==0){
printf("%-2d",i);
n=n/i;
i=1;//將2改為1後。i在完成一次for語句後才會進行i++,如果你設置為2的話,再加就會變成3,這就是你之前錯誤的原因
}
if(n==1) break;
}
}
}
}
以上就是我的回答,具體錯誤都在代碼中備注出來了,如果我的回答對你有用的話,務必採納一下!抱拳!謝了!
㈨ C語言經典演算法:如何較快的分解質因數
將一個正整數分解質因數。例如:輸入90,列印出90=2*3*3*5。初級演算法:#include
#include
#include
int
main()
{
int
n,i;
scanf("%d",&n);
printf("%d=",n);
for(i=2;i
㈩ C語言分解質因數
這樣注釋的已經很好了啊
if(m%k!=0),說明還沒找到因數,每次都是從2開始,逐漸遞增,來找因數的
else,else部分,說明已經找到了因數,找到因數以後,先把因數列印出來,然後讓m等於被除後的數,讓k=2,也就是從2開始,繼續遞增找其他的因數啊
舉個例子,你就明白了,比如15,你要對它進行分解質因數,該怎麼做呢
先讓k=2,發現15%2!=0了,說明2不是它的因數,讓k++
k=3的時候,發現15%3==0了,說明3是它的一個因數,列印出3,讓m=15/3=5,讓k=2
5%2!=0,5%3!=0,5%4!=0,說明2,3,4,都不是5的因數,k繼續自加
k=5,5%5==0了,說明5是5的因數,所以,列印5,m=5/5=1,k=2,這時,就會退出for循環了
逐行分析,見下面:
if(m%k!=0) //m不能被k整除,說明k不是m的因數
{
k++; //就讓k自加1,判斷下一個數是不是m的因數
}
else //m不能被k整除,說明k是m的一個因數
{
printf("%d*",k); //把這個因數k,列印出去
m=m/k; //從m中把因數k去掉,如果不去掉,下一個又會找到因數k的,那樣就不對了
k=2;//讓k重新等於2,也就是重新從2開始找m的因數
}