题解 | #大整数的因子#

大整数的因子

http://www.nowcoder.com/practice/3d6cee12fbf54ea99bb165cbaba5823d

给大家一个完整的大数除法模板,而且返回了余数。

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

vector<int> div(vector<int> &A, int b, int &r)
{
    vector<int> C;
    r = 0;
    for (int i = A.size() - 1; i >= 0; --i)
    {
        r = r * 10 + A[i];
        C.push_back(r / b);
        r %= b;
    }

    reverse(C.begin(), C.end());
    while (C.size() > 1 && C.back() == 0)
        C.pop_back();
    return C;
}

int main()
{
    string c;
    while (cin >> c && c != "-1")
    {
        vector<int> a, ans;
        for (int i = c.size() - 1; i >= 0; --i)
            a.push_back(c[i] - '0');
        for (int i = 2; i <= 9; ++i)
        {
            int r = 0;
            auto res = div(a, i, r);
            if (r == 0)
                ans.push_back(i);
        }
         if (ans.empty())
             cout << "none";
         else
             for (int i = 0; i < ans.size(); ++i)
                 cout << ans[i] << " ";
        cout << endl;
    }
    return 0;
}
全部评论

相关推荐

05-07 17:58
门头沟学院 Java
wuwuwuoow:1.简历字体有些怪怪的,用啥写的? 2.Redis 一主二从为什么能解决双写一致性? 3.乐观锁指的是 SQL 层面的库存判断?比如 stock > 0。个人认为这种不算乐观锁,更像是乐观锁的思想,写 SQL 避免不了悲观锁的 4.奖项证书如果不是 ACM,说实话没什么必要写 5.逻辑过期时间为什么能解决缓存击穿问题?逻辑过期指的是什么 其实也没什么多大要改的。海投吧
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务