一些常见的算法题

质因数分解

       for (int i = 2; i <= n; i++) {
           while (n % i == 0) {
               cout << i <<" ";
               n = n / i;
           }
           if (n == 1) {
               break;
           }
       }

求1-n中和为m的子集

void print(vector<int>& nums) {
    for (int i = 1; i<nums.size(); i++) {
        if (nums[i] == 1) cout << i << " ";
    }
    cout << endl;
}
void findSum(int sum, int n, vector<int>& nums) {
    if (sum < 1 || n < 1) { return; }
    if (sum == n) {
        nums[n] = 1;
        print(nums);
        nums[n] = 0;
    }
    nums[n] = 1;
    findSum(sum - n, n - 1, nums);
    nums[n] = 0;
    findSum(sum, n - 1, nums);
}
int main() {
    int n, m;
    cin >> n >> m;
    vector<int> nums(n + 1);
    findSum(m, n, nums);
    return 0;
}

保留最大的数

#include <iostream>
#include <string>
using namespace std;
int main(){
    string s;
    int k;
    cin >> s >> k;
    int index = 0;
    if(k >= s.size()){
        cout << 0;
    }
    while(k--){
        if(index < 0){
            index = 0;
        }
        while(index < s.size()-1 && s[index] >= s[index+1]){
            index++;
        }
        s.erase(index, 1);
        index--;
    }
    cout << s;
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值