0

可能重复:
在Objective-C中将小数转换为分数?

我正在尝试制作一个简单的应用程序来将十进制形式转换为分数形式。十进制值设置为 UISlider 的值,但我应该如何获得分数形式的分数?我应该用 double 还是 float 声明它,我应该如何告诉应用程序以分数形式打印出来?

4

2 回答 2

0

您想从实数返回小数近似值吗?例如 0.3333 ~ "1/3"。你可以试试这个:

#import <Foundation/Foundation.h>

char out[20];

static char *fractApprox(double r, long d) {
    double atof();
    int atoi();
    void exit();

    long m[2][2];
    double x, startx;
    long maxden;
    long ai;

    startx = x = r;
    maxden = d;

    /* initialize matrix */
    m[0][0] = m[1][1] = 1;
    m[0][1] = m[1][0] = 0;

    /* loop finding terms until denom gets too big */
    while (m[1][0] *  ( ai = (long)x ) + m[1][1] <= maxden) {
        long t;
        t = m[0][0] * ai + m[0][1];
        m[0][1] = m[0][0];
        m[0][0] = t;
        t = m[1][0] * ai + m[1][1];
        m[1][1] = m[1][0];
        m[1][0] = t;
        if(x==(double)ai) break;     // AF: division by zero
        x = 1/(x - (double) ai);
        if(x>(double)0x7FFFFFFF) break;  // AF: representation failure
    }

    ai = (maxden - m[1][1]) / m[1][0];
    m[0][0] = m[0][0] * ai + m[0][1];
    m[1][0] = m[1][0] * ai + m[1][1];

    sprintf(out, "%ld/%ld",m[0][0],m[1][0]);
    return out;
}

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

    @autoreleasepool {
        printf("%s",fractApprox(0.342343, 999));
    }
    return 0;
}

打印329/961到控制台。

感谢加州大学欧文分校的 David Eppstein的 C 算法

于 2012-11-17T11:45:56.730 回答
0

将小数转换为小数所需的是GCD。例如:0.535

  1. 0.535 => 535/1000
  2. GCD(535, 1000) => 5
  3. (535/5) / (1000/5) => 107/200。
于 2012-11-17T11:50:32.507 回答