题目链接:传送门

题目:

B. Math
time limit per test
second
memory limit per test
megabytes
input
standard input
output
standard output JATC's math teacher always gives the class some interesting math problems so that they don't get bored. Today the problem is as follows. Given an integer n , you can perform the following operations zero or more times: mul x : multiplies n by x (where x
is an arbitrary positive integer).
sqrt: replaces n
with n−−√ (to apply this operation, n−−√ must be an integer). You can perform these operations as many times as you like. What is the minimum value of n , that can be achieved and what is the minimum number of operations, to achieve that minimum value? Apparently, no one in the class knows the answer to this problem, maybe you can help them?
Input The only line of the input contains a single integer n
(≤n≤ ) — the initial number.
Output Print two integers: the minimum integer n that can be achieved using the described operations and the minimum number of operations required.
Examples
Input
Copy Output
Copy Input
Copy Output
Copy Note In the first example, you can apply the operation mul
to get and then sqrt to get . In the second example, you can first apply sqrt to get
, then mul to get and finally two more sqrt and you get . Note, that even if the initial value of n
is less or equal , it can still become greater than after applying one or more operations.

题目大意:

  输入一个数n,对这个数可以进行两种操作:

  (1)乘上一个任意大小的整数;

  (2)取平方根。(这里要求取平方根前必须为完全平方数

  问使得输入的n经过任意次操作变成最小值时,输出这个最小值和变成最小值所需要的最少的操作数。

  1 ≤ n ≤ 106

思路:

  ①:n的最小值为它所有质因子的乘积;(如果有一个质因子的指数大于1,那么就不是最小的,而且通过操作②③变成最小的)

  ②:操作(1)最多只需要执行一次,用这次操作把n所有质因子的指数都变成相同的,并且这个指数的值为2的幂次(取平方根时幂次会/=2);

  ③:操作(2)的次数就是②步骤结束后,log2(质因子的指数)。

然后把②和③的次数合起来就好了。

实现:

  试除法筛出n所有的质因子pi及其指数ci,则第一个答案a = $\prod_{i=1}^{fatCnt}p_{i}$。(fatCnt为质因子的数量)

  令b = max(ci),令2t为最小的不小于b的2的幂次。

  ①:如果t为0,那么答案为0;(n不可能变得更小了)

  ②:只要有一个ci < 2t,答案就为t+1;(必须要执行一次操作(1),才能不断的开方)

  ③:如果所有的ci = 2t,答案为t。(此时不执行操作(1),就可以不断开方直到最小)

代码:

  (马上去补!)

比赛代码:

#include <bits/stdc++.h>

using namespace std;
const int MAX_N = ;
int prime[MAX_N+];
void getPrime()
{
memset(prime, , sizeof prime);
for (int i = ; i <= MAX_N; i++) {
if (!prime[i]) prime[++prime[]] = i;
for (int j = ; j <= prime[] && prime[j] <= MAX_N/i; j++) {
prime[prime[j]*i] = ;
if (i%prime[j] == ) break;
}
}
} int factor[][];
int fatCnt;
int getFactors(int x)
{
fatCnt = ;
int tmp = x;
for (int i = ; prime[i] <= tmp/prime[i]; i++) {
if (tmp % prime[i] == ) {
factor[fatCnt][] = prime[i];
factor[fatCnt][] = ;
while (tmp % prime[i] == ) {
factor[fatCnt][]++;
tmp /= prime[i];
}
fatCnt++;
}
}
if (tmp > ) {
factor[fatCnt][] = tmp;
factor[fatCnt][] = ;
fatCnt++;
}
return fatCnt;
} int getbin(int x)
{
int tmp = ;
while (tmp < x) {
tmp <<= ;
}
return tmp;
} bool check(int ansb)
{//ÊÇ·ñÓв»Í¬
int cnt = factor[][];
if (cnt != (<<ansb))
return true;
for (int i = ; i < fatCnt; i++) {
if (factor[i][] != cnt)
return true;
}
return false;
} //int bin[21];
int main() {
// bin[0] = 1;
// for (int i = 1; i < 21; i++) bin[i] = bin[i-1] << 1;
getPrime();
int N;
cin >> N;
getFactors((int)N);
int a = , b = ;
for (int i = ; i < fatCnt; i++) {
a *= factor[i][];
b = max(b, getbin(factor[i][]));
}
int ansb = ;
while (b > ) {
ansb++;
b >>= ;
}
if (ansb > && check(ansb)) {
ansb++;
}
cout << a << ' ' << ansb << endl;
return ;
}

Codeforces1062B. Math(合数分解)的更多相关文章

  1. HDU 4610 Cards (合数分解,枚举)

    Cards Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  2. HDU 4497 GCD and LCM (合数分解)

    GCD and LCM Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Total ...

  3. hdu_4497GCD and LCM(合数分解)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4497 GCD and LCM Time Limit: 2000/1000 MS (Java/Other ...

  4. hdu 5317 合数分解+预处理

    RGCDQ Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Submi ...

  5. hdu 4777 树状数组+合数分解

    Rabbit Kingdom Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) T ...

  6. Perfect Pth Powers pku-1730(筛+合数分解)

    题意:x可以表示为bp, 求这个p的最大值,比如 25=52, 64=26,  然后输入x 输出 p 就是一个质因子分解.算法.(表示数据上卡了2个小时.) 合数质因子分解模板. ]; ]; ; ;n ...

  7. pku1365 Prime Land (数论,合数分解模板)

    题意:给你一个个数对a, b 表示ab这样的每个数相乘的一个数n,求n-1的质数因子并且每个指数因子k所对应的次数 h. 先把合数分解模板乖乖放上: ; ans != ; ++i) { ) { num ...

  8. 莫比乌斯函数 51nod-1240(合数分解试除法)

    就是输出n时,莫比乌斯函数的值.直接将n唯一分解即可. 思路:筛出105以内的素数,因为109开方,105就差不多.当一个大数还没有被1000个素数分解,那么这个数基本上可以认为是素数(为合数为小概率 ...

  9. csu 1801(合数分解+排列组合)

    1801: Mr. S’s Romance Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 15  Solved: 5[Submit][Status][W ...

随机推荐

  1. 剑指offer(12)数值的整数次方

    题目描述 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 题目分析 这道题用传统的方法也可以做,只不过效率太低,这里我们用到快速幂的方法 ...

  2. mongodb 设置权限

    切换到要加密的数据库use diary 创建有 readWrite 权限的用户db.createUser({ user: "youuser", pwd: "youpass ...

  3. Jenkins安装及配置

    Jenkins 简介 Jenkins 是一个开源项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能.它的功能包括: 1.持续的 ...

  4. 补充一下 sizeof

    sizeof是一个运算符,给出某个类型或变量在内存中所占据的字节数 sizeof(int) //告诉你int占据几个字节 sizeof(i) //告诉你i这个变量占据几个字节 注:sizeof是静态运 ...

  5. App自动更新(DownloadManager下载器)

    一.开门见山 代码: object AppUpdateManager { const val APP_UPDATE_APK = "update.apk" private var b ...

  6. Hive常用操作命令

    创建数据库>create database db_name;>create database if not exists db_name;//创建一个不存在的数据库final查看数据库&g ...

  7. JS中如何判断对象是对象还是数组

    JS中如何判断对象是对象还是数组 一.总结 一句话总结:typeof Array.isArray === "function",Array.isArray(value)和Objec ...

  8. HTTP协议(二)之确保web安全的HTTPS

    一.概述 https并非是应用层的一种新协议.只是HTTP通信接口部分用SSL和TLS协议替代. 通常,HTTP直接和TCP通信.当使用SSL时,则演变成先和SSL通信,再由SSL和TCP通信了. 简 ...

  9. 『Python』内存分析_list和array

    零.预备知识 在Python中,列表是一个动态的指针数组,而array模块所提供的array对象则是保存相同类型的数值的动态数组.由于array直接保存值,因此它所使用的内存比列表少.列表和array ...

  10. Gitlab CR

    Gitlab 进行 CR 的强限制,原理很简单. 实现起来,利用的是 git 自身的 custom_hooks 的支持,以及需要对 gitlab 做一点操作,对它的数据库开放一个只读权限的账号,来处理 ...