bzoj 3629
给出数 $n$
记 $f(x)$ 表示 $x$ 的因子和
求出所有 $x$ 使得 $f(x) = n$
考虑 $x = p_1 ^{a_1} * p_2 ^ {a_2} * \cdots * p_k ^ {a_k}$
那么 $f(x) = (1 + p_1 + p_1 ^ 2 + \cdots + p_1 ^ {a_1}) * (1 + p_2 + p_2 ^ 2 + \cdots + p_2 ^ {a_2}) * \cdots * (1 + p_k + p_k
^ 2 + \cdots + p_k ^ {a_k})$
因此可以爆搜枚举 $p, a$
Dfs(Now_result, prime_pos, x_remind) {}
分别表示
1.当前结果,即枚举到的素数的指数次幂的乘积,即 $p_i ^ {a_i}$ 的乘积
2.当前枚举到的素数位置 首先要求出 $1e5, \sqrt(limit)$ 内的素数
3.给出的 $x$ 在枚举了之前的数后还剩多少
对于答案的录入
1.如果 x_remind = 1 ,相当于枚举到了这样一种形式 $() * () * () * p_i ^ 0$, 显然当前 Now_result 可以录入.
2.如果 x_remind - 1 是一个 大于等于 Prime[Prime_pos] 的素数,显然 (x_remind - 1) * Now_result 可以录入.
考虑这样的话我们已经枚举到了这样的一种形式 $() * () * () * (p_i + 1)$, 所以还原之前的数就是 p_i * Now_result.
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cmath>
#include <cstring> using namespace std; #define gc getchar() inline int read() {
int x = ; char c = gc;
while(c < '' || c > '') c = gc;
while(c >= '' && c <= '') x = x * + c - '', c = gc;
return x;
} const int N = 1e5 + ; #define LL long long LL Prime[N], Mark[N], Ans_js;
LL Answer[N], tot, n; void Get_prime() {
for(int i = ; i <= N - ; i ++) {
if(!Mark[i]) Prime[++ tot] = i;
for(int j = ; j <= tot && Prime[j] * i < N; j ++) {
Mark[Prime[j] * i] = ;
if(i % Prime[j] == ) break;
}
}
} bool Is_prime(LL x) {
if(x == ) return ;
for(int i = ; Prime[i] * Prime[i] <= x; i ++) {
if(x % Prime[i] == ) return ;
}
return ;
} void Dfs(LL Now_result, int prime_pos, LL x_remind) {
if(x_remind == ) {
Answer[++ Ans_js] = Now_result;
return ;
}
if(x_remind - >= Prime[prime_pos] && Is_prime(x_remind - )) {
Answer[++ Ans_js] = (x_remind - ) * Now_result;
}
for(int i = prime_pos; Prime[i] * Prime[i] <= x_remind; i ++) {
for(LL tmp = Prime[i] + , imp = Prime[i]; tmp <= x_remind; imp *= Prime[i], tmp += imp) {
if(x_remind % tmp == ) Dfs(Now_result * imp, i + , x_remind / tmp);
}
}
} int main() {
Get_prime();
while(scanf("%lld", &n) == ) {
Ans_js = ;
Dfs(, , n);
sort(Answer + , Answer + Ans_js + );
cout << Ans_js << "\n";
for(int i = ; i < Ans_js; i ++) cout << Answer[i] << " ";
if(Ans_js) cout << Answer[Ans_js] << "\n";
}
return ;
}
bzoj 3629的更多相关文章
- bzoj 3629 [JLOI2014]聪明的燕姿(约数和,搜索)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3629 [题意] 给定S,找出所有约数和为S的数. [思路] 若n=p1^a1*p2^a ...
- bzoj 3629 [JLOI2014]聪明的燕姿——约数和定理+dfs
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3629 如果要搜索,肯定得质因数分解吧:就应该朝这个方向想. **约数和定理: 对于任意一个大 ...
- [BZOJ 3629][ JLOI2014 ]聪明的燕姿
这道题考试选择打表,完美爆零.. 算数基本定理: 任何一个大于1的自然数N,都可以唯一分解成有限个质数的乘积N=P₁^a₁ P₂^a₂…Pn^an,这里P₁<P₂<…<Pn均为质数, ...
- bzoj 3629 聪明的燕姿 约数和+dfs
考试只筛到了30分,正解dfs...... 对于任意N=P1^a1*P2^a2*......*Pn^an, F(N)=(P1^0+P1^1+...+P1^a1)(P2^0+P2^1+...+P2^a2 ...
- BZOJ 3629 JLOI2014 聪明的燕姿 约数和+DFS
根据约数和公式来拆s,最后再把答案乘出来,我们发先这样的话递归层数不会太大每层枚举次数也不会太多,然而我们再来个剪枝就好了 #include<cstdio> #include<ios ...
- bzoj 3629: [JLOI2014]聪明的燕姿【线性筛+dfs】
数论+爆搜 详见这位大佬https://blog.csdn.net/eolv99/article/details/39644419 #include<iostream> #include& ...
- BZOJ 3629 约数和定理+搜索
呃呃 看到了这道题 没有任何思路-- 百度了一发题解 说要用约数和定理 就查了一发 http://baike.so.com/doc/7207502-7432191.html (不会的可以先学习一下) ...
- LOJ 2234/BZOJ 3629 聪明的燕姿(数论+DFS)
题面 传送门 分析 看到约数之和,我们首先想到约数和公式 若$ x=\prod_{i=1}^{n}p_i^{k_i} \(,则x的约数和为\) \prod_{i=1}^{n} \sum_{j=0}^{ ...
- 【BZOJ】初级水题列表——献给那些想要进军BZOJ的OIers(自用,怕荒废了最后的六月考试月,刷刷水题,水水更健康)
BZOJ初级水题列表——献给那些想要进军BZOJ的OIers 代码长度解释一切! 注:以下代码描述均为C++ RunID User Problem Result Memory Time Code_Le ...
随机推荐
- Kubernetes 学习笔记(一):基础概念
个人笔记,仅本人查阅使用,不保证正确. 零.微服务 微服务架构专注于应用解耦合,通过将应用彻底地组件化和服务化,每个微服务只包含一个非常小的功能,比如权限管理.日志收集等等.由这一组微服务组合起来,提 ...
- C++11 特性
之前工作中开发/维护的模块大多都是 "远古代码",只能编译 C++98,很多 C++11 的特性都忘得差不多了,再回顾一下 右值引用&转移语义: 消除两个对象交互时不必要的 ...
- Java安装和环境配置
Java安装和环境配置 从事Java开发第一关就是安装JAVA环境. 我们要安装JDK, 全称Java开发全套. 其中包含了JRE(运行时环境), 如果你打游戏的时候可能会提示你缺少JRE. 我们要做 ...
- vsCode 代码不高亮显示的问题——安装Vetur插件
vsCode 代码不高亮显示: 解决办法:安装Vetur插件 点击左侧菜单的扩展-->搜索Vetur-->点击安装-->安装完成重启vsCode
- CentOS 6.5 iptables原理详解以及功能说明
CentOS 6.5 iptables原理详解以及功能说明 来源 https://blog.51cto.com/tanxw/1389114 前言 iptables其实就是Linux下的一个开源的信息过 ...
- 我自己用C++写了个GMM(Gaussian mixture model)模型
我自己用C++写了个GMM(Gaussian mixture model)模型 Written for an assignment 之前粗粗了解了GMM的原理,但是没有细看,现在有个Assignmen ...
- POJ1979(Red and Black)--FloodFill
题目在这里 题目意思是这样的,一个人起始位置在 '@' 处,他在途中能到达的地方为 ' . ' 而 '#' 是障碍物,他不能到达. 问途中他所有能到达的 '.'的数量是多少 ? ...
- Linux查找文件之Find命令
Linux系统文件中常用属性包括以下内容:名称,大小,权限,属主,属组,修改时间,访问时间等.在庞大的Linux系统中查询文件,需要借助查找工具来实现,依此可以查询相同或指定属性的文件,本文所讲的查询 ...
- Java反射机制、注解及JPA实现
1.java反射概述 JAVA反射机制是在运行状态中,对于任意一个实体类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意方法和属性:这种动态获取信息以及动态调用对象方法的功能称 ...
- Java 之 Junit 单元测试
Junit 单元测试 测试分类: 1.黑盒测试:不需要写代码,给输入值,看程序是否能够输出期望的值. 2.白盒测试:需要写代码.关注程序具体的执行流程. Junit 测试:(属于白盒测试) 步骤: 1 ...