(编辑:什么是代码高尔夫:代码高尔夫是挑战,解决一个特定的问题,以最少的代码字符计数,无论你喜欢哪种语言。
More info here on Meta StackOverflow。)
代码高尔夫球手,这是一个字符串操作的挑战。
电子邮件地址验证,但没有正则表达式(或类似的解析库)当然。这不是电子邮件地址,而是您可以编写下面给出的不同字符串操作和约束的时间。
规则如下(是的,我知道,这不符合RFC规定,但这些将是这个挑战的5个规则):
> @之前至少有1个字符@:
A-Z,a-z,0-9,. (period),_ (underscore)
> @必须存在,只有一次
john@smith.com ^
> Period(。)必须一直存在@
john@smith.com ^
> @和以下之间至少有1个[A-Z,a-z]字符。 (期)
john@s.com ^
>最后只有2个[A-Z,a-z]字符。期
john@smith.ab ^^
请仅发布方法/函数,这将需要一个字符串(提议的电子邮件地址),然后根据电子邮件地址有效(true)或无效(false)返回布尔值结果(true / false)。
Samples: b@w.org (valid/true) @w.org (invalid/false) b@c@d.org (invalid/false) test@org (invalid/false) test@%.org (invalid/false) s%p@m.org (invalid/false) j_r@x.c.il (invalid/false) j_r@x.mil (valid/true) r..t@x.tw (valid/true) foo@a%.com (invalid/false)
祝你好运!
C89(166个字符)
原文链接:https://www.f2er.com/regex/357432.html#define B(c)isalnum(c)|c==46|c==95 #define C(x)if(!v|*i++-x)return!1; #define D(x)for(v=0;x(*i);++i)++v; v;e(char*i){D(B)C(64)D(isalpha)C(46)D(isalpha)return!*i&v>1;}
不重入,但可以多次运行。测试床:
#include<stdio.h> #include<assert.h> main(){ assert(e("b@w.org")); assert(e("r..t@x.tw")); assert(e("j_r@x.mil")); assert(!e("b@c@d.org")); assert(!e("test@%.org")); assert(!e("j_r@x.c.il")); assert(!e("@w.org")); assert(!e("test@org")); assert(!e("s%p@m.org")); assert(!e("foo@a%.com")); puts("success!"); }