二刷
#include<iostream>
using namespace std;
int main(){
string s;
cin>>s;
if(s.size()==3){
for(int i=0;i<s[0]-'0';i++) cout<<"B";
for(int i=0;i<s[1]-'0';i++) cout<<"S";
for(int i=1;i<=s[2]-'0';i++) cout<<i;
}else if(s.size()==2){
for(int i=0;i<s[0]-'0';i++) cout<<"S";
for(int i=1;i<=s[1]-'0';i++) cout<<i;
}else for(int i=1;i<=s[0]-'0';i++) cout<<i;
return 0;
}
代码与思考
学习:
1 求各个位数
2 奇妙的输出方式
分析:因为n⼩于1000,所以数字不会超过百位~输⼊数据⾸先保存在a中,然后将a的每⼀个数字保存
在int b[3]中,然后将b[2]、b[1]、b[0]中存储的数字看作输出次数依次输出B、S和12…b[0]~
#include <iostream>
using namespace std;
int main() {
int a, i = 0;
cin >> a;
int b[3] = {0};//初始化数组
//下面这段代码背过,用于在非字符串中求各位数字
while (a != 0) {
b[i++] = a % 10;//将数的每一位数存放在数组中
a = a / 10;
}
//万万没想到还能这样单个输出
for (int k = 0; k < b[2]; k++)//注意这里是小于,没有等于
cout << "B";
for (int k = 0; k < b[1]; k++)
cout << "S";
for (int k = 0; k < b[0]; k++)
cout << k + 1;
return 0;
}
这是我写了一个代码再下面,结果是部分正确,也不知道是什么情况。
#include <iostream>
#include <string>
using namespace std;
int main() {
string s;
cin >> s;
int B, S, N;
B = (s[0] - '0');
S = (s[1] - '0');
N = (s[2] - '0');
string b, s1, n, str;
for (int i = 1; i <= B; i++) {
b += 'B';
}
for (int i = 1; i <= S; i++) {
s1 += 'S';
}
n.append("123456789", N);
str = b + s1 + n;
cout << str;
system("pause");
return 0;
}