前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >uva 11549 CALCULATOR CONUNDRUM

uva 11549 CALCULATOR CONUNDRUM

作者头像
xindoo
发布2021-01-22 12:53:39
2810
发布2021-01-22 12:53:39
举报
文章被收录于专栏:XINDOO的专栏XINDOO的专栏

题目链接

刘汝佳算法竞赛经典入门训练指南p42

代码1:

代码语言:javascript
复制
#include <set>
#include <iostream>
#include <sstream>
using namespace std;

int next(int n, int k)
{
    stringstream ss;
    ss <<(long long)k*k;
    string s = ss.str();
    if (s.length() > n)
        s = s.substr(0, n);
    int ans = 0;
    stringstream ss2(s);
    ss2 >> ans;
    return ans;
}

int main()
{
    int t;
    int n, k;
    cin>>t;
    while (t--)
    {
        cin>>n>>k;
        set<int> s;
        int ans = k;
        while (!s.count(k))
        {
            s.insert(k);
            if (k > ans)
                ans = k;
            k = next(n, k);
        }
        cout << ans << endl;
    }
    return 0;
}

代码2:

代码语言:javascript
复制
#include <set>
#include <iostream>
#include <sstream>
using namespace std;

int next(int n, int k)
{
    int buf[10];
    if (!k)
        return 0;
    long long k2 = (long long)k*k;
    int l = 0;
    while (k2 > 0)
    {
        buf[l++] = k2%10; k2 /= 10;
    }
    if (n > l)
        n = l;
    int ans = 0;
    for (int i = 0; i < n; i++)
        ans = ans*10 + buf[--l];
    return ans;
}

int main()
{
    int t;
    int n, k;
    cin>>t;
    while (t--)
    {
        cin>>n>>k;
        set<int> s;
        int ans = k;
        while (!s.count(k))
        {
            s.insert(k);
            if (k > ans)
                ans = k;
            k = next(n, k);
        }
        cout << ans << endl;
    }
    return 0;
}

代码3(Floyd判圈法):

代码语言:javascript
复制
#include <set>
#include <iostream>
#include <sstream>
using namespace std;
int buf[10];
int next(int n, int k)
{
    if (!k)
        return 0;
    long long k2 = (long long)k*k;
    int l = 0;
    while (k2 > 0)
    {
        buf[l++] = k2%10; k2 /= 10;
    }
    if (n > l)
        n = l;
    int ans = 0;
    for (int i = 0; i < n; i++)
        ans = ans*10 + buf[--l];
    return ans;
}

int main()
{
    int t;
    int n, k;
    cin>>t;
    while (t--)
    {
        cin>>n>>k;
        int ans = k;
        int k1 = k, k2 = k;
        do
        {
            k1 = next(n, k1);
            k2 = next(n, k2);
            if (k2 < ans)
                ans = k2;
            k2 = next(n, k2);
            if (k2 < ans)
                ans = k2;
        }while (k1 != k2);
        cout << ans << endl;
    }
    return 0;
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2013-05-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档