zoukankan      html  css  js  c++  java
  • POJ1016 Numbers That Count

    题目来源:http://poj.org/problem?id=1016

    题目大意:

      对一个非负整数定义一种运算(inventory):数这个数中各个数字出现的次数,然后按顺序记录下来。比如“5553141”有2个1,1个3,一个4,3个5,于是运算后为“21131435”,对于这种运算有的数字有着有趣的性质:如“31123314”,它运算后的结果和它本身是一样的(self-inventorying)。如果做j次inventory运算后,第j次迭代的结果是self-inventorying的,则称这个数是j步后self-inventory.此外,如果n进行j次迭代后,再进行k(k>=2)次迭代,结果与第j次迭代的结果相等,称它 enters an inventory loop of length k.

      写一个程序,判断一系列非负整数属于上面三种数字的哪一种(只考虑15次迭代)。

    输入:一系列的非负整数,每个最多80位,-1标志结束。

    输出:对于每一个输入的整数n,根据该数的性质输出一下四条语句中的一条:

    n is self-inventorying 
    n is self-inventorying after j steps 
    n enters an inventory loop of length k 
    n can not be classified after 15 iterations


    Sample Input

    22 
    31123314 
    314213241519 
    21221314 
    111222234459 
    -1

    Sample Output

    22 is self-inventorying 
    31123314 is self-inventorying 
    314213241519 enters an inventory loop of length 2 
    21221314 is self-inventorying after 2 steps 
    111222234459 enters an inventory loop of length 2

    这道题我就是用简单的模拟做的,具体实现见代码。

     1 //////////////////////////////////////////////////////////////////////////
     2 //        POJ1016 Numbers That Count
     3 //        Memory: 272K        Time: 47MS
     4 //        Language: C++        Result: Accepted
     5 //////////////////////////////////////////////////////////////////////////
     6 
     7 #include <iostream>
     8 #include <string>
     9 
    10 using namespace std;
    11 
    12 string int2str(int n) {
    13     string str;
    14     if (n == 0)
    15         str = "0";
    16     while (n != 0) {
    17         str.insert(str.begin(), '0' + n % 10);
    18         n /= 10;
    19     }
    20     return str;
    21 }
    22 
    23 int main() {
    24     while (true) {
    25         string strList[16];
    26         int digCount[10];
    27         int j = 0, k = 0;
    28         cin >> strList[0];
    29         if (strList[0][0] == '-') {
    30             break;
    31         }
    32         int count = 0;
    33         bool flag = false;
    34         for (int i = 1; i < 16; ++i) {
    35             for (int k = 0; k < 10; ++k) {
    36                 digCount[k] = 0;
    37             }
    38             for (int t = 0; t < strList[i - 1].size(); ++t) {
    39                 int d = strList[i - 1][t] - '0';
    40                 ++digCount[d];
    41             }
    42             strList[i] = "";
    43             for (int k = 0; k < 10; ++k) {
    44                 if (digCount[k] == 0) {
    45                     continue;
    46                 }
    47                 strList[i] += int2str(digCount[k]);
    48                 strList[i] += int2str(k);
    49             }
    50             if (strList[i] == strList[i - 1]) {
    51                 if (i == 1) {
    52                     cout << strList[0] << " is self-inventorying" << endl;
    53                     flag = true;
    54                     break;
    55                 } else {
    56                     cout << strList[0] << " is self-inventorying after " << i - 1 <<" steps" << endl;
    57                     flag = true;
    58                     break;
    59                 }
    60             }
    61             for (int j = 0; j < i; ++j) {
    62                 if (strList[i] == strList[j]) {
    63                     cout << strList[0] << " enters an inventory loop of length " << i - j << endl;
    64                     flag = true;
    65                     break;
    66                 }
    67             }
    68             if (flag == true) {
    69                 break;
    70             }
    71         }
    72         if (flag == true) {
    73             continue;
    74         } else {
    75             cout << strList[0] << " can not be classified after 15 iterations" << endl;
    76         }
    77     }
    78     system("pause");
    79 }
    View Code
  • 相关阅读:
    Javascript知识汇总------手写图片上传插件
    Javascript知识汇总------面向对象手写弹窗插件
    Javascript知识汇总------面向对象手写拖拽插件
    Javascript知识汇总------获取构造函数constructor名称和一些字符串处理方法
    博客搬家啦
    NOI 2015 荷马史诗【BZOJ 4198】k叉Huffman树
    BZOJ 1044 木棍分割 解题报告(二分+DP)
    BZOJ 1051 最受欢迎的牛 解题报告
    BZOJ 2467 解题报告
    BZOJ 4619 Swap Space 解题报告
  • 原文地址:https://www.cnblogs.com/dengeven/p/3227774.html
Copyright © 2011-2022 走看看