UVA 11549 calcular conundrum 计算机老谜题

题目大意
用一个老式计算器,只显示n位数字,输入一个整数k后计算,计算器会反复平方,直至溢出,每次溢出只显示最高的n位,计算器会一直平方下去,直到出现重复的数字
分析
题目中已经暗示了计算器显示的数会出现循环,不妨一个一个的模拟,直至出现重复的数字,我们使用集合把出现过的数字进行记录。
上代码

#include<iostream>
#include<algorithm>
#include<set>
#include<string>
#include<sstream>
#define maxn 1000000+10
using namespace std;

int n, k;
set<int>se;
int cal(int n, int k)			//计算后取k位;
{
	stringstream ss;
	ss << (long long)k*k;
	string s = ss.str();
	if (s.length() > n)		//与谁比较!!!!!!
		s = s.substr(0,n);
	//cout << s << endl;;
	stringstream ss2(s);
	int ans;
	ss2 >> ans;
	return ans;
}
int main()
{
	int T;
	cin >> T;
	while (T--)
	{
		cin >> n >> k;
		
			 ans = k;
			while (!se.count(k))			//以前没有出现过;
			{
				//cout << k << endl;
				se.insert(k);
				k =cal(n, k);
				if (k > ans) ans = k;
			}
			cout<<ans<<endl;
		}
		return 0;
}

这个算法运行时会异常慢,主要数字符的输入输出流,我们尝试优化 因为字符串的输入流满我们将其替换。因为计算的数不可能超过100位,我们定义一个100位的数组就足够了,当然为了保险起见,也可以将数组开大。

int self_cal(int n, int k)
{
	int a[100];
	long long kk = k * k;
	int len = 0;
	int i = 1;
	if (!k)   return 0;
	while (kk > 0)
	{
		a[len++] = kk % 10;	
		kk /= 10;
	}
	if (n > len)		n = len;
	int ans = 0;
	for (int i = 0; i < n; i++)
	{
		ans = ans * 10 + a[--len];
	}
	return ans;
}

这样的话运行时间就会降低了,还有一种方法可以降到更低,那就是Floyd判圈法,想象一下如果两个孩子赛跑,如果是直线跑道,速度慢的孩子和速度快的孩子永远不可能相遇,但如果时第二种情况,就迟早能相遇。
在这里插入图片描述

		int ans = k;
		int k2 = k,k1=k;
		do {				//floyd套圈法;
			k1 = cal(n,k1);
			k2 = cal(n, k2); if (k2 > ans)	ans = k2; //cout << k2<<endl;
			k2 = cal(n, k2); if (k2 > ans)ans = k2;	//cout << k2<<endl;
		} while (k2 != k1);		
		cout << ans << endl;
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值