对我自己这个方法也是醉了。。2333,简单粗暴,有朝一日要写出简短精悍的代码来~!
让我们用字母B来表示“百”、字母S表示“十”,用“12...n”来表示个位数字n(<10),换个格式来输出任一个不超过3位的正整数。例如234应该被输出为BBSSS1234,因为它有2个“百”、3个“十”、以及个位的4。
输入格式:每个测试输入包含1个测试用例,给出正整数n(<1000)。
输出格式:每个测试用例的输出占一行,用规定的格式输出n。
输入样例1:234输出样例1:
BBSSS1234输入样例2:
23输出样例2:
SS123
#include<iostream>
#include<stdio.h>
using namespace std;
int main(){
int n,i=0,a[3];
cin>>n;
while(n){
a[i++]=n%10;
n=n/10;
}
switch(a[2]){
case 1:printf("B");break;
case 2:printf("BB");break;
case 3:printf("BBB");break;
case 4:printf("BBBB");break;
case 5:printf("BBBBB");break;
case 6:printf("BBBBBB");break;
case 7:printf("BBBBBBB");break;
case 8:printf("BBBBBBBB");break;
case 9:printf("BBBBBBBBB");break;
case 0:printf("");break;
}
switch(a[1]){
case 1:printf("S");break;
case 2:printf("SS");break;
case 3:printf("SSS");break;
case 4:printf("SSSS");break;
case 5:printf("SSSSS");break;
case 6:printf("SSSSSS");break;
case 7:printf("SSSSSSS");break;
case 8:printf("SSSSSSSS");break;
case 9:printf("SSSSSSSSS");break;
case 0:printf("");break;
}
switch(a[0]){
case 1:printf("1");break;
case 2:printf("12");break;
case 3:printf("123");break;
case 4:printf("1234");break;
case 5:printf("12345");break;
case 6:printf("123456");break;
case 7:printf("1234567");break;
case 8:printf("12345678");break;
case 9:printf("123456789");break;
case 0:printf("");break;
}
}