题目描述:

把一个整数的每个数位都平方后求和,又得到一个整数,我们称这个整数为:位平方和。

对新得到的整数仍然可以继续这一运算过程。

比如,给定整数为4,则一系列的运算结果为:

16,37,58,89,....

本题的要求是,已知一个整数x,求第n步的运算结果。

数据格式要求:

输入,两个整数x n,中间以空格分开。表示求x的第n步位平方和。其中,x,n都大于0,且小于100000。
输出,一个整数,表示所求结果。

例如,
输入:
4 3
则程序应该输出:
58

再例如,
输入:
1314 10
则程序应该输出:
20

资源约定:
峰值内存消耗(含虚拟机) < 256M
CPU消耗  < 1000ms

请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。

所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。
注意:不要使用package语句。不要使用jdk1.7及以上版本的特性。
注意:主类的名字必须是:Main,否则按无效代码处理。

正确算法:

这道题目其实就是第七届蓝桥杯中的平方怪圈,所以这道题有个规律-->不管开始取的是什么数字,最终如果不是落入1,就是落入同一个循环圈。

这道题目如果用普通方法写,似乎不会超时。我这里写了一个优化的方法。

import java.util.Scanner;

public class Main {
/**
* 优化
*/
public static void f(int x, int n) {
//循环圈
int arr[] = { 37, 58, 89, 145, 42, 20, 4, 16 };
while (n-- > 0) {
if (x == 1) {
System.out.println(1);
return;
}
if (x == 37) {
int index = (n + 1) % 8;
System.out.println(index);
System.out.println(arr[index]);
return;
}
int sum = 0;
while (x != 0) {
sum += Math.pow(x % 10, 2);
x /= 10;
}
x = sum; }
//如果在第n步时还没有找到循环圈,那么就会到达这里
System.out.println(x);
} public static void main(String[] args) {
Scanner input = new Scanner(System.in);
while (input.hasNext()) {
int x = input.nextInt();
int n = input.nextInt();
int tmp = x;
for (int i = 0; i < n; i++) {
int sum = 0;
while (x != 0) {
sum += Math.pow(x % 10, 2);
x /= 10;
}
x = sum;
System.out.println("x="+x);
}
System.out.println(x);
//测试两种方法得到的答案是否一样
System.out.println("----");
f(tmp, n);
}
}
}

最新文章

  1. pip 与pip3
  2. Hybrid App移动应用开发初探
  3. web前端开发分享-css,js工具篇
  4. Chrome扩展开发之二——Chrome扩展中脚本的运行机制和通信方式
  5. PSP进度(11~16)
  6. ImageMagick之PDF转换成图片(image)
  7. 【转】Oracle 执行动态语句
  8. 1-1 Windows应用程序的特点
  9. excel让每个单元格的宽度随着字体自动变动的两种方式(有更好方法的大神,请忽略,求评论下)
  10. 如何解决WebkitBrowser使用出错“Failed to initialize activation context”
  11. httpclient发送multipart/form-data类型参数和用MultipartRequest接收参数
  12. C#性能优化实践
  13. [PWA] Enable Push Notification in your web app
  14. What is WCF
  15. JDK与Apache Tomcat服务器的安装步骤
  16. 201521123075 《Java程序设计》第14周学习总结
  17. beta冲刺计划安排
  18. jdk8中的stream
  19. CentOS_7下安装Nginx服务
  20. (整理)REHL6.5_安装本地yum

热门文章

  1. JFreeChart教程(二)(转)
  2. js 弹出对话框的方法总结
  3. 并不对劲的字符串专题(二):kmp
  4. bzoj4720
  5. 使用 SQL Server Management Studio的活动和监视器 查看运行的SQL语句
  6. UVa 11401 Triangle Counting (计数DP)
  7. 如何管理第三方接口token过期时间
  8. centos7开启路由转发
  9. POJ 3683 Priest John's Busiest Day
  10. linux自动连接校园网设置