***牛客网--大整数的因子

大整数除法算法
本文介绍了一种处理大整数除法问题的算法,特别适用于判断大整数是否能被2到9之间的整数整除。通过计算大整数对各小整数的模运算,快速找出所有可能的除数。

大整数除法

题目描述 已知正整数k满足2<=k<=9,现给出长度最大为30位的十进制非负整数c,求所有能整除c的k.
输入描述:若干个非负整数c,c的位数<=30 每行一个c
输出描述: 每一个c的结果占一行 1) 若存在满足 c%k == 0
的k,输出所有这样的k,中间用空格隔开,最后一个k后面没有空格。 2) 若没有这样的k则输出"none"

注意整数溢出问题 不要对-1进行计算

#include<bits/stdc++.h>
using namespace std;

//求大整数除法的余数
int mod(string s,int a){
    int plus=0;//前一位的余数
    for(int i=0;i<s.length();i++)
    {
        int now=plus*10+(s[i]-'0');
        plus=now%a;
    }
    return plus;
}

int main()
{
    string c;
    int flag=0;//此方法针对除最后一个数之外,其余数后都有空格的题目要求
    while(cin>>c&&c!="-1")
    {
        for(int i=2;i<=9;i++)
        {
            if(mod(c,i)==0) 
            {   if(flag)  cout<<" ";
                else flag=1;
                cout<<i;
            }
        }
        if(!flag)  cout<<"none";
        cout<<endl;
    }
    return 0;
}
### 关于华为机试中的C++解法 针对华为机试,在牛客网上可以找到许多利用C++解答的经典题目。以下是几个典型例子及其简洁易懂的实方式。 #### HJ6 质数因子 此题旨在找出给定整数的所有质数因子并按从小到大顺序输出。对于这个问题,可以通过不断尝试除以最小可能的因数来解决[^2]。 ```cpp #include <iostream> using namespace std; void primeFactors(int n){ while (n%2==0){ cout << "2 "; n /= 2; } for (int i=3; i*i<=n; i+=2){ while(n%i==0){ cout << i << " "; n /= i; } } if (n>2) cout << n; } int main(){ int num; cin >> num; primeFactors(num); } ``` #### HJ21 简单密码破解 该问题涉及将特定模式编码后的字符串还原成原始字符集。通过构建映射表并将输入串逐转换可得正解[^3]。 ```cpp #include <map> #include <string> using namespace std; string decodeSimplePassword(const string& encodedStr) { map<char, char> mapping = {{&#39;a&#39;,&#39;m&#39;}, {&#39;b&#39;,&#39;n&#39;}, /*...*/}; // 完善完整的映射关系 string decodedResult = ""; for(auto ch : encodedStr){ if(mapping.find(ch)!=mapping.end()){ decodedResult += mapping[ch]; }else{ decodedResult += ch; } } return decodedResult; } int main() { string inputString; getline(cin, inputString); cout << decodeSimplePassword(inputString) << endl; return 0; } ``` #### 最长严格递增子序列(不要连续) 本题要计算数组中最长上升子序列长度。采用动态规划的方法能够有效地解决问题[^4]。 ```cpp #include <iostream> #include <vector> #include <algorithm> using namespace std; int longestIncreasingSubsequence(vector<int>& nums) { if(nums.empty()) return 0; vector<int> dp(nums.size(), 1); int maxLength = 1; for(size_t i = 1; i != nums.size(); ++i){ for(size_t j = 0; j < i; ++j){ if(nums[j]<nums[i]){ dp[i] = max(dp[i], dp[j]+1); } } maxLength = max(maxLength, dp[i]); } return maxLength; } int main() { int sizeOfArray; cin >> sizeOfArray; vector<int> arrayElements(sizeOfArray); for(auto& elem : arrayElements){ cin >> elem; } cout << longestIncreasingSubsequence(arrayElements) << endl; return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值