Captcha Cracker
Time Limit: 1000ms
Memory Limit: 262144KB
64-bit integer IO format: %lld Java class name: Main
www.02469.com(本网页纯属虚构,如有雷同,纯属巧合),是一个资源丰富的教学资源网站,好学的SK同学经常访问这个网站。通常来说,网站为了安全考虑,登录的时候都需要用户输入验证码,这就让SK同学非常不爽了。
SK同学希望你能帮他写一个程序来自动识别验证码的内容,验证码由小写字母和阿拉伯数字组成,你需要识别出其中所有的以及这个数字对应的英文单词,并按照它们在验证码中出现的顺序以数字形式输出。
为了表示感谢,SK同学愿意跟你分享他私藏的教学资源(详情请参考气球上的logo)。
Input
第一行是一个正整数,表示测试数据的组数,
每组测试数据只有一行,包含一个长度不超过的只由小写字母和阿拉伯数字组成的非空字符串。
Output
对于每组测试数据,输出一行字符串,表示识别出的验证码。
Sample Input
2
onetwothreefourfiveseven
0two4six6siiiiix
Sample Output
24
02466
Hint
0 - zero
2 - two
4 - four
6 - six
9 - nine
题解:我的思路就是碰到0 2 4 6 9 中的哪一个就存到一个数组里,其实也可以直接输出……
#include<bits/stdc++.h>
#include<stdio.h>
#include<iostream>
#include<algorithm>
#include<string.h>
#include<stdlib.h>
#include<time.h>
#include<string>
#include<math.h>
#include<map>
#include<queue>
#include<stack>
#define INF 0x3f3f3f3f
#define ll long long
#define For(i,a,b) for(int i=a;i<b;i++)
#define sf(a) scanf("%d",&a)
#define sfs(a) scanf("%s",a)
#define sff(a,b) scanf("%d%d",&a,&b)
#define sfff(a,b,c) scanf("%d%d%d",&a,&b,&c)
#define pf(a) printf("%d\n",a)
#define P() printf("\n")
#define mem(a,b) memset(a,b,sizeof(a))
using namespace std;
char x[100005];
int y[100005];
int main()
{
int t;
sf(t);
while(t--)
{
sfs(x);
int l=strlen(x);
int p=0;
for(int i=0;i<l;i++)
{
if(x[i]=='0'||x[i]=='4'||x[i]=='6'||x[i]=='9'||x[i]=='2')
{
y[p++]=x[i]-'0';
}
else if(x[i]=='z')
{
if(x[i+1]=='e'&&x[i+2]=='r'&&x[i+3]=='o')
{
y[p++]=0;
i=i+3;
}
}
else if(x[i]=='t')
{
if(x[i+1]=='w'&&x[i+2]=='o')
{
y[p++]=2;
i+=2;
}
}
else if(x[i]=='f')
{
if(x[i+1]=='o'&&x[i+2]=='u'&&x[i+3]=='r')
{
y[p++]=4;
i+=3;
}
}
else if(x[i]=='s')
{
if(x[i+1]=='i'&&x[i+2]=='x')
{
y[p++]=6;
i+=2;
}
}
else if(x[i]=='n')
{
if(x[i+1]=='i'&&x[i+2]=='n'&&x[i+3]=='e')
{
y[p++]=9;
i+=3;
}
}
}
for(int i=0;i<p;i++)
printf("%d",y[i]);
printf("\n");
}
}