创建一个Fraction类(分数)实现分数的加减乘除,比较大小、约分等方法。

.h文件中的代码


#import <Foundation/Foundation.h>


@interface Fracton : NSObject

{

    NSInteger molecule;//分子

    NSInteger denominator;//分母

}

@property NSInteger molecule;

@property NSInteger denominator;

-(void)reductionOfFraction;//约分

- (void)add:(Fracton *)fenshu3;//

- (Fracton *)sub:(Fracton *)fenshu3;//

- (void)mult:(Fracton *)fenshu3;//乘法

- (void)division:(Fracton *)fenshu3;//除法

- (void)compare:(Fracton *)fenshu3;//比较


@end


.m文件中的代码


#import "Fracton.h"


@implementation Fracton


@synthesize molecule = _molecule;

@synthesize denominator = _denominator;

-(void)reductionOfFraction{

    NSInteger a = self.molecule;

    NSInteger b = self.denominator;

    NSInteger c = 0;

    while (b != 0) {

        c = a % b;

        a = b;

        b = c;

    }

        NSLog(@"%ld/%ld",self .molecule/a,self. denominator/a);

    }

- (void)add:(Fracton *)fenshu3{

    Fracton *fenshu2 =[Fracton alloc];

    fenshu2.molecule = (self.molecule * fenshu3.denominator) + (fenshu3.molecule * self.denominator);

    fenshu2.denominator = self.denominator * fenshu3.denominator;

    [fenshu2 reductionOfFraction];

}

- (Fracton *)sub:(Fracton *)fenshu3{

    Fracton *fenshu2 =[Fracton alloc];

    fenshu2.molecule = self.molecule * fenshu3.denominator - fenshu3.molecule * self.denominator;

    fenshu2.denominator = self.denominator * fenshu3.denominator;

    [fenshu2 reductionOfFraction];

    return fenshu2;

}

- (void)mult:(Fracton *)fenshu3{

    Fracton *fenshu2 =[Fracton alloc];

    fenshu2.molecule = self.molecule * fenshu3.molecule;

    fenshu2.denominator = self.denominator * fenshu3.denominator;

    [fenshu2 reductionOfFraction];

    

    

}//乘法

- (void)division:(Fracton *)fenshu3{

    Fracton *fenshu2 =[Fracton alloc];

    fenshu2.molecule = self.molecule * fenshu3.denominator;

    fenshu2.denominator = self.denominator * fenshu3.molecule;

    [fenshu2 reductionOfFraction];

    

}//除法

- (void)compare:(Fracton *)fenshu3{

    Fracton *fenshu2 =[Fracton alloc];

       fenshu2 = [self sub:fenshu3];

    if (fenshu2.molecule > 0) {

        NSLog(@"分数1大于分数2");

    }else if(fenshu2.molecule == 0)

    {

        NSLog(@"分数等于分数2");

    }else{

        NSLog(@"分数小于分数2");

    }

}

   @end


main函数中的实现


nt main(int argc, const char * argv[])

{


    @autoreleasepool {

        Fracton *fenshu1 = [Fracton alloc];

        fenshu1.molecule = 4;

        fenshu1.denominator = 6;

        Fracton *fenshu2 = [Fracton alloc];

        fenshu2.molecule = 2;

        fenshu2.denominator = 5;

        [fenshu1 add:fenshu2];

        [fenshu1 sub:fenshu2];

        [fenshu1 mult:fenshu2];

        [fenshu1 compare:fenshu2];

        [fenshu1 reductionOfFraction];


}

  return 0;

}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值