题目类型 简单题
题目意思
给你一个最多100字符长的字符串, 问是否满足这个格式 -> <username>@<hostname>[/resource]
其中
<username>是一个只包含 字母或数字或下划线 的长度为 1 - 16 的字符串
<hostname>是一个由 若干个以字符 '.' 进行分隔的单词 组成的长度为 1 - 32的字符串, 其中单词的限制和 <username> 一样
resource的限制与 <username>一样 [/resource] 的意思是 <hostname> 后面可以跟零个或多个 /resource
解题方法
直接 从左到右遍历字符串, 然后统计相关信息就行了
注意
1. 根据题目意思 @是一定要有的, @前和@后必须至少有一个合法的字符 字符/ 没有也是可以的, 但是一旦有后面必须跟一个非空字符串
2. 那些字符串的长度限制是 1-x, 那么就意味然至少要有1个,没有是不行的 例如 <username>@h1.h2.h3/r1 字符串h1,h2,h3与r1均不能为空
参考代码 - 有疑问的地方在下方留言 看到会尽快回复的
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <queue>
using namespace std;
typedef long long LL;
char str[1000];
char s[100][100];
int main() {
while(scanf("%s", str) != EOF) {
int len = strlen(str);
bool f1 = false;
bool f2 = true;
int k = 0, i;
for( i=0; i<len; i++ ) {
if(str[i] == '@') {
f1 = true;
break;
}
else {
if(!((str[i] >= 'A' && str[i] <= 'Z') || (str[i] >= 'a' && str[i] <= 'z') ||(str[i]>='0'&&str[i]<='9')|| str[i] == '_')) {
f2 = false;
break;
}
else k++;
if(k > 16) {
f2 = false;
break;
}
}
}
if(f1 == false || f2 == false || k < 1) {
printf("NO\n");
continue;
}
k = 0;
int k2 = 0;
for( i=i+1; i<len; i++ ) {
if(str[i] == '/') {
break;
}
else if(str[i] == '.') {
if(k2 == 0) {
f2 = false;
break;
}
k2 = 0;
continue;
}
else {
if(!((str[i] >= 'A' && str[i] <= 'Z') || (str[i] >= 'a' && str[i] <= 'z')||(str[i]>='0'&&str[i]<='9') || str[i] == '_')) {
f2 = false;
break;
}
else k++, k2++;
if(k2 > 16 || k > 32) {
f2 = false;
break;
}
}
}
if(f2 == false || k2 == 0 || k == 0) {
printf("NO\n");
continue;
}
if(i == len) {
printf("YES\n");
continue;
}
k = 0;
for( i=i+1; i<len; i++ ) {
if(str[i] == '/') {
if(k == 0) {
f2 = false;
break;
}
k = 0;
continue;
}
else {
if(!((str[i] >= 'A' && str[i] <= 'Z') || (str[i] >= 'a' && str[i] <= 'z')||(str[i]>='0'&&str[i]<='9') || str[i] == '_')) {
f2 = false;
break;
}
else k++;
if(k > 16) {
f2 = false;
break;
}
}
}
if(f2 == false || k == 0) {
printf("NO\n");
}
else printf("YES\n");
}
return 0;
}