算法笔记.求约数

代码实现:

cpp 复制代码
#include<iostream>
using namespace std;
#include<vector>
void check(int x)
{
    vector<int> v;
    for(int i = 1;i<= x/i;i++)
    {
        if(x%i == 0) 
        {
            cout << i<<" ";
            v.push_back(i);
        }
    }
    
    for(int i = v.size()-1;i>=0;i--)
    {
        if(x/v[i] == v[i]) continue;
        cout << x/v[i]<<" ";
    }
    cout <<endl;
}


int main()
{
    int n;
    cin>>n;
    
    while(n--)
    {
        int x;
        scanf("%d",&x);
        check(x);
    }
    return 0;
}

注意:约数只需要枚举到 ,对应的大于约数直接算出来,相同约数只取一个

相关推荐
fqbqrr12 小时前
2606C++,C++构的多态
开发语言·c++
问心无愧051312 小时前
ctf show web入门111
android·前端·笔记
小欣加油13 小时前
leetcode56 合并区间
c++·算法·leetcode·职场和发展
lqqjuly13 小时前
前沿算法深度解析(二)
人工智能·算法·机器学习
Yolo_TvT14 小时前
C++:析构函数
c++
徐小夕14 小时前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
akunkuntaimei14 小时前
2026年高考数学各省真题及答案(完整版)
算法·高考
Hello:CodeWorld15 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi816 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
和平宇宙17 小时前
AI笔记005. hermes-DeepSeek V4 Pro, 128K上下文引发的探索
前端·人工智能·笔记