| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 5147 人关注过本帖
标题:分数求和
只看楼主 加入收藏
unight
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2017-4-5
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:2 
分数求和
【问题描述】分数包含分子分母两项,定义一个有关分数的结构体类型,写一个函数来计算两分数之和,结果仍然为分数类型,注意约分。再编写main函数来输入两分数,调用函数求和,再输出两分数的和。
分数求和的函数体怎么写啊
搜索更多相关主题的帖子: 结构体 
2017-05-17 21:13
yangfrancis
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:141
帖 子:1510
专家分:7661
注 册:2014-5-19
收藏
得分:20 
#include<stdio.h>
struct fraction
{
    int upper;//分子
    int lower;//分母
};
struct fraction GetSum(struct fraction a,struct fraction b)
{
    int divider;//分子分母最大公约数
    struct fraction result;
    if(!(a.lower&&b.lower))//检查分母
    {
        printf("非法数值!");exit(0);
    }
    result.lower=a.lower*b.lower;
    result.upper=a.upper*b.lower+b.upper*a.lower;
    divider=result.lower>result.upper?result.upper:result.lower;
    do
    {
        if(result.upper%divider==0&&result.lower%divider==0)
        {
            result.lower/=divider;
            result.upper/=divider;
            return result;//约分后的情况
        }
    }while(--divider>1);
    return result;//不能再约分的情况
}
void main()
{
    struct fraction a,b,c;
    a.lower=5;a.upper=3;
    b.lower=13;b.upper=8;
    c=GetSum(a,b);
    printf("%d/%d+%d/%d=%d/%d\n",a.upper,a.lower,b.upper,b.lower,c.upper,c.lower);
    return 0;
}
2017-05-17 22:37
unight
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2017-4-5
收藏
得分:0 
#include<stdio.h>
struct fraction
{
    int upper;//分子
    int lower;//分母
};
struct fraction GetSum(struct fraction a,struct fraction b)
{
    int divider;//分子分母最大公约数
    struct fraction result;
    if(!(a.lower&&b.lower))//检查分母
    {
        printf("非法数值!");exit(0);
    }
    result.lower=a.lower*b.lower;
    result.upper=a.upper*b.lower+b.upper*a.lower;
    divider=result.lower>result.upper?result.upper:result.lower;
    do
    {
        if(result.upper%divider==0&&result.lower%divider==0)
        {
            result.lower/=divider;
            result.upper/=divider;
            return result;//约分后的情况
        }
    }while(--divider>1);
    return result;//不能再约分的情况
}
void main()
{   printf("please enter the fenzi,fenmu of two complex:\n");
    struct fraction a,b,c;
    scanf("%d %d",&a.upper,&a.lower);
    scanf("%d %d",&b.upper,&b.lower);
    c=GetSum(a,b);
    printf("the result is %d/%d",c.upper,c.lower);
    return 0;
}
感谢感谢!自己根据题意完善了一下
2017-05-18 14:34
快速回复:分数求和
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.029854 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved