zoukankan      html  css  js  c++  java
  • ACM 6174问题

    6174问题

    时间限制:1000 ms  |  内存限制:65535 KB
    难度:2
     
    描述

    假设你有一个各位数字互不相同的四位数,把所有的数字从大到小排序后得到a,从小到大后得到b,然后用a-b替换原来这个数,并且继续操作。例如,从1234出发,依次可以得到4321-1234=3087、8730-378=8352、8532-2358=6174,又回到了它自己!现在要你写一个程序来判断一个四位数经过多少次这样的操作能出现循环,并且求出操作的次数

    比如输入1234执行顺序是1234->3087->8352->6174->6174,输出是4

     
    输入
    第一行输入n,代表有n组测试数据。
    接下来n行每行都写一个各位数字互不相同的四位数
    输出
    经过多少次上面描述的操作才能出现循环
    样例输入
    1
    1234
    样例输出
    4
    #include <iostream>
    #include <vector>
    #include <algorithm>
    #include <iterator>
    using namespace std;
    vector<int> numCnt;
    int solve(int num){
        vector<int> a(4);
        a[0] = num%10;
        a[1] = num/10%10;
        a[2] = num/100%10;
        a[3] = num/1000;
        sort(a.begin(),a.end());
        int num1 = a[3]*1000+a[2]*100 +a[1]*10+a[0];
        int num2 = a[3]+a[2]*10+a[1]*100 + a[0]*1000;
        vector<int>::iterator iter = find(numCnt.begin(),numCnt.end(),num1-num2);
        if(iter!=numCnt.end()) return distance(numCnt.begin(),iter)+1;
        else {
            numCnt.push_back(num1-num2);
            return solve(num1-num2);
        }
    }
    
    int main(){
        int n;
        cin >> n;
        for(int icase  = 0 ; icase < n; ++icase){
            int num;
            cin >> num;
            numCnt.push_back(num);
            cout<<solve(num)<<endl;
            numCnt.clear();
        }
    }
  • 相关阅读:
    系统调用简单总结
    系统调用原理详解
    总结:c 语言与Linux操作系统的关系
    poj3171 Cleaning Shifts
    洛谷P1032 字串变换
    poj3662 Telephone Lines
    洛谷P1073 最优贸易
    Uva1330/poj1964 City Game
    poj2559/SP1805 Largest Rectangle in a Histogram
    洛谷 P1196 [NOI2002]银河英雄传说
  • 原文地址:https://www.cnblogs.com/xiongqiangcs/p/3637107.html
Copyright © 2011-2022 走看看