Fraction to Recurring Decimal leetcode

Given two integers representing the numerator and denominator of a fraction, return the fraction in string format.

If the fractional part is repeating, enclose the repeating part in parentheses.

For example,

  • Given numerator = 1, denominator = 2, return "0.5".
  • Given numerator = 2, denominator = 1, return "2".
  • Given numerator = 2, denominator = 3, return "0.(6)".

 

Credits:
Special thanks to @Shangrila for adding this problem and creating all test cases.

 

Subscribe to see which companies asked this question

 
这个题的思路简单,
1.根据两个数得到结果正负,如负数,添加"-"
2.计算小数点前部分,添加到字符串
3.循环计算小数点后部分,并利用hashmap记录每次的除数,如果在hashmap中存在过,说明存在循环小数部分
4.将循环部分括起来
 
第一次写出的答案如下:
string fractionToDecimal(int numerator, int denominator) {
    string ret;
    int a = numerator;
    int b = denominator;

    ret = to_string(a / b);
    a = a % b;
    if (a)
        ret.push_back('.');
    else
        return ret;
    unordered_map<int, int> m;
    int i = ret.length() - 1;
    while (a)
    {
        i++;
        if (m.find(a) != m.end()) {
            ret.insert(ret.begin() + m[a], '(');
            ret.push_back(')');
            break;
        }
        m[a] = i;
        a *= 10;
        if (a < b) {
            ret.push_back('0');
            continue;
        }
        ret.push_back('0' + a / b);
        a = a % b;
    }
    return ret;
}

提交后发现,有特殊情况没有考虑到。-2147483648 / -1 这种情况会溢出,所以需要使用long类型替换int。

参考修改后代码如下:

string fractionToDecimal(int numerator, int denominator) {
    if (!numerator) return "0";
    string ret;
    if (numerator < 0 ^ denominator < 0) ret += '-';
    long a = numerator < 0 ? (long)numerator * (-1) : (long)numerator;
    long b = denominator < 0 ? (long)denominator * (-1) : (long)denominator;
    long c = a / b;
    ret += to_string(c);
    a = a % b;
    if (!a) return ret;
    ret.push_back('.');
    unordered_map<long, long> m;
    int i = ret.length() - 1;
    while (a)
    {
        i++;
        if (m.find(a) != m.end()) {
            ret.insert(ret.begin() + m[a], '(');
            ret.push_back(')');
            break;
        }
        m[a] = i;
        a *= 10;
        if (a < b) {
            ret.push_back('0');
            continue;
        }
        ret.push_back('0' + a / b);
        a = a % b;
    }
    return ret;
}

虽然在leetcode上提交成功了,但是在vs2015上运行是错误的,

long a = numerator < 0 ? (long)numerator * (-1) : (long)numerator;

这一句如果是numerator是-2147483648,a会是-2147483648,这非常诡异。不知道vs2015编译器对于这个问题是怎么解决的。

转载于:https://www.cnblogs.com/sdlwlxf/p/5152236.html

Android resource fraction refers to the ability to specify resource values as fractions or percentages of a parent resource. This is commonly used in Android development to create responsive layouts that adapt to different screen sizes and resolutions. For example, instead of specifying a fixed width or height for a view, you can use resource fractions to define the size relative to the parent container. This allows the view to scale proportionally when the container's size changes. To use resource fractions in Android, you can define them in XML resource files using the "fraction" unit. For instance, you can set the width of a view to half of the parent container by using a fraction value of "0.5". Here's an example of how you can use resource fractions in an XML layout file: ```xml <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <View android:layout_width="@fraction/0.5" android:layout_height="0dp" android:layout_weight="1" android:background="@color/red" /> <View android:layout_width="@fraction/0.5" android:layout_height="0dp" android:layout_weight="1" android:background="@color/blue" /> </LinearLayout> ``` In this example, two views are placed inside a LinearLayout with a vertical orientation. Both views have a width defined as half of the parent container, using the "@fraction/0.5" resource value. Using resource fractions can help create more flexible and responsive UI designs in Android applications.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值