2016SDAU课程练习一 1012
来源:互联网 发布:长效避孕药 知乎 编辑:程序博客网 时间:2024/05/16 10:21
Problem M
Problem DescriptionCurrent work in cryptography involves (among other things) large prime numbers and computing powers of numbers among these primes. Work in this area has resulted in the practical use of results from number theory and other branches of mathematics once considered to be only of theoretical interest.
This problem involves the efficient computation of integer roots of numbers.
Given an integer n>=1 and an integer p>= 1 you have to write a program that determines the n th positive root of p. In this problem, given such integers n and p, p will always be of the form k to the nth. power, for an integer k (this integer is what your program must find).
This problem involves the efficient computation of integer roots of numbers.
Given an integer n>=1 and an integer p>= 1 you have to write a program that determines the n th positive root of p. In this problem, given such integers n and p, p will always be of the form k to the nth. power, for an integer k (this integer is what your program must find).
Input
The input consists of a sequence of integer pairs n and p with each integer on a line by itself. For all such pairs 1<=n<= 200, 1<=p<10<sup>101</sup> and there exists an integer k, 1<=k<=10<sup>9</sup> such that k<sup>n</sup> = p.
The input consists of a sequence of integer pairs n and p with each integer on a line by itself. For all such pairs 1<=n<= 200, 1<=p<10<sup>101</sup> and there exists an integer k, 1<=k<=10<sup>9</sup> such that k<sup>n</sup> = p.
Output
For each integer pair n and p the value k should be printed, i.e., the number k such that k n =p.
Sample Input
2 16
3 27
7 4357186184021382204544
Sample Output
4
3
1234
题意:给定m,你;n的p次幂等于m,求p
思路:这个题借鉴了一下别人的思路,用一下pow函数问题就迎刃而解了。要注意四舍五入的问题,浮点数向整数转化时,采用的是直接丢弃小数部分的方式,所以结果会偏小,如果要四舍五入的话,运算结果要加上0.5。
感想:感觉一开始把问题复杂了,其实就是个求幂的问题
AC代码:
#include <cstdio>
#include<iostream>
#include<stdio.h>
#include<vector>
#include<algorithm>
#include<numeric>
#include<math.h>
#include<string.h>
#include<map>
#include<set>
#include<vector>
using namespace std;
int main()
{
double n,p;
int i;
while(cin>>n)
{
cin>>p;
i=pow(p,1/n)+0.5;
cout<<i<<endl;
}
}
#include<iostream>
#include<stdio.h>
#include<vector>
#include<algorithm>
#include<numeric>
#include<math.h>
#include<string.h>
#include<map>
#include<set>
#include<vector>
using namespace std;
int main()
{
double n,p;
int i;
while(cin>>n)
{
cin>>p;
i=pow(p,1/n)+0.5;
cout<<i<<endl;
}
}
0 0
- 2016SDAU课程练习一 1012
- 2016SDAU课程练习一1012
- 2016SDAU课程练习一1012 Problem M
- 2016sdau课程练习专题一 1012 problemM
- 2016SDAU课程练习一1004
- 2016SDAU课程练习一1004 E
- 2016SDAU课程练习一1000
- 2016SDAU课程练习一Problem G
- 2016SDAU课程练习一1000A
- 2016SDAU课程练习一1016Q
- 2016SDAU课程练习一1006
- 2016SDAU课程练习一Problem E
- 2016SDAU课程练习一1001
- 2016SDAU课程练习一1016
- 2016SDAU课程练习一 1006
- 2016SDAU课程练习一1005
- 2016SDAU课程练习一1000
- 2016SDAU课程练习一1001
- 第六天、打渔晒网问题
- 使用docker快速构建rails开发环境
- 向量的点乘和叉乘
- Android 之窗口小部件高级篇--App Widget 之 RemoteViews
- Protocol Buffer技术详解(语言规范)
- 2016SDAU课程练习一 1012
- 常见视频文件的编码方式和封装格式
- 自定义EditText的两种方法
- static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别?
- 常用hql
- JAVA中length、length()、size()的区别
- SpringMVC系列核心:处理请求流程
- 强大的数据库操作类DBHelper
- HDU 1875 畅通工程再续(MST)