这是昨天写的一道题,太晚了没有做完就没发出来。
题目描述
继MIUI8推出手机分身功能之后,MIUI9计划推出一个电话号码分身的功能:首先将电话号码中的每个数字加上8取个位,然后使用对应的大写字母代替 ("ZERO", "ONE", "TWO", "THREE", "FOUR", "FIVE", "SIX", "SEVEN", "EIGHT", "NINE"), 然后随机打乱这些字母,所生成的字符串即为电话号码对应的分身。
输入描述:
第一行是一个整数T(1 ≤ T ≤ 100)表示测试样例数;接下来T行,每行给定一个分身后的电话号码的分身(长度在3到10000之间)。
输出描述:
输出T行,分别对应输入中每行字符串对应的分身前的最小电话号码(允许前导0)。
示例1
输入
4 EIGHT ZEROTWOONE OHWETENRTEO OHEWTIEGTHENRTEO
输出
0 234 345 0345
题目主要分析不同数字英文表示的特殊性,难度不大。
#include <iostream>
#include <string.h>
using namespace std;
int main() {
int t;
char n[10004];
int b[10] = {0,0,0,0,0,0,0,0,0,0};
int i,s;
scanf("%d",&t);
while(t--) {
// memset(b,0,sizeof(b));
scanf("%s",&n);
s = strlen(n);
for(i = 0; i< s; i++) {
if(n[i] == 'Z') b[0]++;//0对应2
if(n[i] == 'O') b[1]++;
if(n[i] == 'W') b[2]++;//2对应4
if(n[i] == 'H') b[3]++;
if(n[i] == 'U') b[4]++;//4对应6
if(n[i] == 'F') b[5]++;
if(n[i] == 'X') b[6]++;//6对应8
if(n[i] == 'S') b[7]++;
if(n[i] == 'G') b[8]++;//8对应0
if(n[i] == 'I') b[9]++;
}
b[1] = b[1] - b[0] - b[2] - b[4];//1对应3
b[3] = b[3] - b[8];//3对应5
b[5] = b[5] - b[4];//5对应7
b[7] = b[7] - b[6];//7对应9
b[9] = b[9] - b[8] - b[5]- b[6];//9对应1
while(b[8]--) {
printf("%c",'0');
}
while(b[9]--) {
printf("%c",'1');
}
while(b[0]--) {
printf("%c",'2');
}
while(b[1]--) {
printf("%c",'3');
}
while(b[2]--) {
printf("%c",'4');
}
while(b[3]--) {
printf("%c",'5');
}
while(b[4]--) {
printf("%c",'6');
}
while(b[5]--) {
printf("%c",'7');
}
while(b[6]--) {
printf("%c",'8');
}
while(b[7]--) {
printf("%c",'9');
}
printf("\n");
}
}
这是最后编译成功的代码。
我昨天的代码如下,思路大概一致,但是好像输入上出了问题,今天没心情看了,找时间再来看一下。
#include<iostream>
#include<string>
using namespace std;
int main(void){
int n=0;
string str;
cin>>n;
int arr[n][10];
for(int i=0;i<n;i++){
for(int j=0;j<10;j++){
arr[i][j]=0;
}
}
char c;
for(int i=0;i<=n;i++){
while((c=cin.get())!='\n'){
cin.unget();
cin>>str;
for(int j=0;j<str.length();j++){
if(str[j]=='G'){
arr[i][0]++;
}
else if(str[j]=='W'){
arr[i][1]++;
}
else if(str[j]=='U'){
arr[i][2]++;
}
else if(str[j]=='X'){
arr[i][3]++;
}
else if(str[j]=='R'){
arr[i][4]++;
}
else if(str[j]=='Z'){
arr[i][8]++;
}
else if(str[j]=='F'){
arr[i][5]++;
}
else if(str[j]=='V'){
arr[i][6]++;
}
else if(str[j]=='O'){
arr[i][7]++;
}
else {
arr[i][9]++;
}
}
}
}
for(int i=0;i<n;i++){
while(arr[i][0]>0){
cout<<"0";
arr[i][0]--;
}
while(arr[i][9]>0){
cout<<"1";
arr[i][9]--;
}
while(arr[i][8]>0){
cout<<"2";
arr[i][8]--;
}
while(arr[i][7]>0){
cout<<"3";
arr[i][7]--;
}
while(arr[i][0]>0){
cout<<"4";
arr[i][0]--;
}
while(arr[i][1]>0){
cout<<"5";
arr[i][1]--;
}
while(arr[i][4]>0){
cout<<"6";
arr[i][4]--;
}
while(arr[i][2]>0){
cout<<"7";
arr[i][2]--;
}
while(arr[i][5]>0){
cout<<"8";
arr[i][5]--;
}
while(arr[i][3]>0){
cout<<"9";
arr[i][3]--;
}
while(arr[i][6]>0){
cout<<"10";
arr[i][6]--;
}
cout<<endl;
}
}