當前位置:首頁 » 編程語言 » 循環c語言分數求和
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

循環c語言分數求和

發布時間: 2022-10-03 08:21:51

⑴ 如何用c語言編程輸入兩個分數求和並以最簡分式的方式輸出

#include "stdio.h"
int fun(int num1,int num2)/*求最大公約數函數*/
{
int a,b,temp;
if(num1<num2)
{
temp=num1;
num1=num2;
num2=temp;
}
a=num1;
b=num2;
while(b!=0)/*利用輾除法,直到b為0為止*/
{
temp=a%b;
a=b;
b=temp;
}
return a;
}
main()
{
int a1,a2,b1,b2,c=1,num1,num2;
printf("請輸入第一個分數的分子:\n");
scanf("%d",&a1);
printf("請輸入第一個分數的分母:\n");
scanf("%d",&a2);
printf("請輸入第一個分數的分子:\n");
scanf("%d",&b1);
printf("請輸入第一個分數的分母:\n");
scanf("%d",&b2);
num1=a1*b2+b1*a2;
num2=a2*b2;
c=fun(num1,num2);
num1=num1/c;
num2=num2/c;
if(num2==1)
printf("結果為:%d:",num1);
else
printf("結果為:%d/%d:",num1,num2);
}

⑵ C語言循環求和

1 / i 改成1.0 / i 試試看?這樣變成了浮點數除法。否則是整型除法,1 / i 四捨五入之後變成 0,這樣只會循環一次就退出了,結果自然是1。

⑶ C語言:分數求和

//結構定義中包含兩個成員,分子和分母
structfraction
{
intup,down;/*分子和分母*/
};

/*
相加演算法的核心是找兩個分母的最小公倍數和結果分子分母的最大公約數,分別單獨函數來求
*/
intpubtime(int,int);//最小公倍數
intpubsub(int,int);//最大公約數,可用輾轉相除法求,挺經典的一個方法。

/********分數相加********/
fractionadd(fractionf1,fractionf2)
{
fractionresult;
result.down=pubtime(f1.down,f2.down);
result.up=f1.up*result.down/f1.down+f2.up*result.down/f2.down;
intn=pubsub(result.up,result.down);
result.up/=n;result.down/=n;
returnresult;
}

intpubtime(intn1,intn2)
{
intn=pubsub(n1,n2);
returnn1*n2/n;
}
intpubsub(intn1,intn2)
{
intr=n1;
if(n2>n1)
r=n1,n1=n2,n2=r;
do
{/*輾轉相除*/
r=n1%n2;
if(r==0)break;
n1=n2;n2=r;
}while(true);
returnn2;
}

⑷ c語言分數數列求和

看這數列的找規律:2/1,3/2,5/3,8/5,13/8.......

後一項的分母等於前一項的分子,後一項的分子等於前一項的分母+分子

#include<stdio.h>
intmain()
{
inti,n;
doublesum=0,z,m,zSave;//z,m分別保存分子分母
printf("輸入數值n:");
scanf("%d",&n);
z=2;m=1;
for(i=0;i<n;i++)
{
sum=sum+z/m;
printf("+%.0lf/%.0lf",z,m);
zSave=z;
z=z+m;
m=zSave;
}
printf("=%.6lf",sum);
return0;
}

⑸ 如何用C語言編程輸入兩個分數求和並以最簡分式的方式輸出

輸入可以用如下格式:
unsigned int a,b,c,d;

scanf("%d/%d",&a,&b);/*a/b*/
scanf("%d/%d",&c,&d);/*c/d*/
求最大公因數,可以用輾轉相除法;公分母=b、d的最小公倍數=b*d/b、d的最大公約數,
通分後,分子相加,結果的分子、分母用輾轉相除法求最大公約數,進行約分。
約分後的結果輸出。

⑹ C語言,關於分數數列求和

#include<stdio.h>

int main()
{
int n;
float t,r=0,fm=2,fz=1;

scanf("%d",&n);
while(n--)
{
r+=fm/fz;
t=fm;
fm+=fz;
fz=t;
}
printf("%.6f",r);
return 0;
}

⑺ C語言分數相加求和

#include<stdio.h>
#include<math.h>

intfenzi(inti)//分子就是137132131他們之間的差是246810
{
if(i<=0)
return1;
returni*2+fenzi(i-1);
}

intfenmu(inti)//分母就是2的i+1次方
{
return(int)pow(2,i+1);
}

intmain()
{
doublesum=0;
intflag,x,y;
for(inti=0;i<20;i++)
{
x=fenzi(i);
y=fenmu(i);
flag=pow(-1,i);//+-隨i是奇偶變換
printf("%c%d/%d",flag>0?'+':'-',x,y);
sum+=flag*x*1.0/y;
}
printf("=%lf ",sum);
return0;
}