代码高尔夫 – 代码高尔夫:没有正则表达式的电子邮件地址验证

前端之家收集整理的这篇文章主要介绍了代码高尔夫 – 代码高尔夫:没有正则表达式的电子邮件地址验证前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
(编辑:什么是代码高尔夫:代码高尔夫是挑战,解决一个特定的问题,以最少的代码字符计数,无论你喜欢哪种语言。 More info here on Meta StackOverflow。)

代码高尔夫球手,这是一个字符串操作的挑战。

电子邮件地址验证,但没有正则表达式(或类似的解析库)当然。这不是电子邮件地址,而是您可以编写下面给出的不同字符串操作和约束的时间。

规则如下(是的,我知道,这不符合RFC规定,但这些将是这个挑战的5个规则):

> @之前至少有1个字符@:

  1. A-Z,a-z,0-9,. (period),_ (underscore)

> @必须存在,只有一次

  1. john@smith.com
  2. ^

> Period(。)必须一直存在@

  1. john@smith.com
  2. ^

> @和以下之间至少有1个[A-Z,a-z]字符。 (期)

  1. john@s.com
  2. ^

>最后只有2个[A-Z,a-z]字符。期

  1. john@smith.ab
  2. ^^

请仅发布方法/函数,这将需要一个字符串(提议的电子邮件地址),然后根据电子邮件地址有效(true)或无效(false)返回布尔值结果(true / false)。

  1. Samples:
  2. b@w.org (valid/true) @w.org (invalid/false)
  3. b@c@d.org (invalid/false) test@org (invalid/false)
  4. test@%.org (invalid/false) s%p@m.org (invalid/false)
  5. j_r@x.c.il (invalid/false) j_r@x.mil (valid/true)
  6. r..t@x.tw (valid/true) foo@a%.com (invalid/false)

祝你好运!

C89(166个字符)
  1. #define B(c)isalnum(c)|c==46|c==95
  2. #define C(x)if(!v|*i++-x)return!1;
  3. #define D(x)for(v=0;x(*i);++i)++v;
  4. v;e(char*i){D(B)C(64)D(isalpha)C(46)D(isalpha)return!*i&v>1;}

不重入,但可以多次运行。测试床:

  1. #include<stdio.h>
  2. #include<assert.h>
  3. main(){
  4. assert(e("b@w.org"));
  5. assert(e("r..t@x.tw"));
  6. assert(e("j_r@x.mil"));
  7. assert(!e("b@c@d.org"));
  8. assert(!e("test@%.org"));
  9. assert(!e("j_r@x.c.il"));
  10. assert(!e("@w.org"));
  11. assert(!e("test@org"));
  12. assert(!e("s%p@m.org"));
  13. assert(!e("foo@a%.com"));
  14. puts("success!");
  15. }

猜你在找的正则表达式相关文章