CodeForces 21A Jabber ID (简单题)

题目类型  简单题

题目意思
给你一个最多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;
}


你可能感兴趣的:(codeforces,简单题)