1006. 换个格式输出整数 (15)

原创 2015年11月20日 21:16:21

1006. 换个格式输出整数 (15)

让我们用字母B来表示“百”、字母S表示“十”,用“12…n”来表示个位数字n(<10),换个格式来输出任一个不超过3位的正整数。例如234应该被输出为BBSSS1234,因为它有2个“百”、3个“十”、以及个位的4。

输入格式:每个测试输入包含1个测试用例,给出正整数n(<1000)。

输出格式:每个测试用例的输出占一行,用规定的格式输出n。
输入样例1:

234

输出样例1:

BBSSS1234

输入样例2:

23

输出样例2:

SS123


//温故知新,修改于2016.7.30
#include<iostream>
#include<string>
#include<algorithm>
using namespace std;
int main()
{
    int num;
    cin>>num;
    string result="";
    int flag=-1;
    while(num!=0){
        int data=num%10;
        switch(flag){
        case -1:
            while(data--)
                result+=(data+1)+'0';
            break;
        case 0:
            while(data--)
                result+='S';
            break;
        case 1:
            while(data--)
                result+='B';
            break;    
        }
        flag++;
        num=num/10;
    }
    reverse(result.begin(),result.end());
    cout<<result<<endl;
    return 0;
}
#include<iostream>
#include<vector>
using namespace std;
int main()
{
    cout<<"please input a Natural number(<1000)"<<endl;
    int num;
    cin>>num;
    vector<int> result;
    while(num!=0)
    {
        int data=num%10;
        result.push_back(data);
        num=num/10;
    }//按照从低位到高位存储输入数据
    for(int i=0;i!=result.size();i++)
    {
        int id=result.size()-i-1;
        char newNum;
        switch(id)
        {
            case 2:
                newNum='B';
                break;
            case 1:
                newNum='S';
                break;
            case 0:
                newNum='g';
                break;

        }
        for(int j=0;j<result[id];j++)
        {
            if(newNum=='g')
                cout<<(j+1);
            else
               cout<<newNum;

        }
    }
    cout<<endl;
    return 0;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

1006. 换个格式输出整数 (15)

让我们用字母B来表示“百”、字母S表示“十”,用“12...n”来表示个位数字n(<10),换个格式来输出任一个不超过3位的正整数。例如234应该被输出为BBSSS1234,因为它有2个“百”、3个“...
  • Y_215
  • Y_215
  • 2016-12-12 03:55
  • 126

1006. 换个格式输出整数 (15)

让我们用字母B来表示“百”、字母S表示“十”,用“12...n”来表示个位数字n( 输入格式:每个测试输入包含1个测试用例,给出正整数n( 输出格式:每个测试用例的输出占一行,用规定的格式输出n。...

1006. 换个格式输出整数 (15)

1006. 换个格式输出整数 (15) 第一个是我写的,很麻烦。第二个是别人的简介方案。 在我的方案中,malloc()函数,来动态给指针分配内存。这里需要注意了, 第一:malloc分配内存没...

浙江大学PAT_乙级_1006. 换个格式输出整数 (15)

c++栈实现

1006 换个格式输出整数

// 让我们用字母B来表示“百”、字母S表示“十”,用“12...n”来表示个位数字n(<10),换个格式来输出任一个不超过3位的正整数。例如234应该被输出为BBSSS1234,因为它有2个“百”、...

PAT---换个格式输出整数

让我们用字母B来表示“百”、字母S表示“十”,用“12...n”来表示个位数字n( 输入格式:每个测试输入包含1个测试用例,给出正整数n( 输出格式:每个测试用例的输出占一行,用规定的格式输出n。...

PAT--换个格式输出整数

让我们用字母B来表示“百”、字母S表示“十”,用“12...n”来表示个位数字n( 输入格式:每个测试输入包含1个测试用例,给出正整数n( 输出格式:每个测试用例的输出占一行,用规定的格式输出n。...

【笔试】15、输入三个整数x,y,z,请把这三个数由小到大输出。

/** * 题目:输入三个整数x,y,z,请把这三个数由小到大输出。 * 时间:2015年7月29日11:01:06 * 文件:Lianxi15.java * 作者:cutter_poi...

能被15整除的最大整数

能被15整除的最大整数2010/05/15 下午 08:34题目给定一个只包含数字 [0..9] 的字符串,求使用字符串中的某些字符,构造一个能够被15整除的最大整数。注意,字符串中的每个字符只能使用...

循环-03. 求符合给定条件的整数集(15)

循环-03. 求符合给定条件的整数集(15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)