zoukankan      html  css  js  c++  java
  • PAT 甲级 1023 Have Fun with Numbers (20分)

    Notice that the number 123456789 is a 9-digit number consisting exactly the numbers from 1 to 9, with no duplication. Double it we will obtain 246913578, which happens to be another 9-digit number consisting exactly the numbers from 1 to 9, only in a different permutation. Check to see the result if we double it again!

    Now you are suppose to check if there are more numbers with this property. That is, double a given number with k digits, you are to tell if the resulting number consists of only a permutation of the digits in the original number.

    Input Specification:

    Each input contains one test case. Each case contains one positive integer with no more than 20 digits.

    Output Specification:

    For each test case, first print in a line "Yes" if doubling the input number gives a number that consists of only a permutation of the digits in the original number, or "No" if not. Then in the next line, print the doubled number.

    Sample Input:

    1234567899

    Sample Output:

    Yes
    2469135798

    AC三部曲:1、[ 判断数字进位 ]    2、[ vector记录分类 ]   3、[sort后比较输出 ]

     1 #include<bits/stdc++.h>
     2 using namespace std;
     3 
     4 vector<int> v, vv, s2; //v  double_v answer
     5 
     6 int main()
     7 {
     8     string s; cin >> s;//字符串输入
     9     int len = s.length();//数字位数
    10     for(int i = 0; i < len; i++) v.push_back(s[i]-'0');//字符—>数字 加入v中
    11     sort(v.begin(), v.end());//从小到大排序
    12     
    13     int next = 0;//进位标志
    14     for(int i = len-1; i >= 0; i--)  {
    15         if( 2*(s[i]-'0') < 10 ) {   
    16             int x = 2*(s[i]-'0') + next;//double后无法进位 + next(0)
    17             vv.push_back(x); s2.push_back(x);
    18             next = 0;
    19         }
    20         else {
    21             int x = 2*(s[i]-'0') % 10 + next;//double后进位 + next(1)
    22             vv.push_back(x); s2.push_back(x);
    23             next = 1;
    24         }
    25     }
    26     if(next) {//next == 1 因此double后的位数大于原数位数
    27         cout << "No" << endl << "1";
    28         for(int i = vv.size()-1; i >= 0; i--) cout << vv[i];
    29     }
    30     else {//前后位数相等
    31         sort(vv.begin(), vv.end());
    32         int flag = 1;
    33         for(int i = 0; i < v.size(); i++) if(v[i] != vv[i]) { flag = 0; break; }
    34         if(flag) cout << "Yes" << endl; 
    35         else cout << "No" << endl;
    36         for(int i = s2.size()-1; i >= 0; i--) cout << s2[i];
    37     }
    38     return 0;
    39 }
    View Code
  • 相关阅读:
    C#中Linq查询基本操作
    Python中的四种数据结构
    20200917练习题
    SRS搭建自己的直播、点播系统
    20200916练习题
    20200915练习题
    20200914练习题
    20200911练习题
    UTF-8最多编码字符数(最多可以容纳多少数量的字符)?
    k8s新手必看
  • 原文地址:https://www.cnblogs.com/kamisamalz/p/13570009.html
Copyright © 2011-2022 走看看