邮箱验证 ——ACM
生活随笔
收集整理的這篇文章主要介紹了
邮箱验证 ——ACM
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
郵箱驗證
POJ 注冊的時候需要用戶輸入郵箱,驗證郵箱的規則包括: 1)有且僅有一個'@'符號 2)'@'和'.'不能出現在字符串的首和尾 3)'@'之后至少要有一個'.',并且'@'不能和'.'直接相連 滿足以上3條的字符串為合法郵箱,否則不合法, 編寫程序驗證輸入是否合法Input
輸入包含若干行,每一行為一個代驗證的郵箱地址,長度小于100Output
每一行輸入對應一行輸出 如果驗證合法,輸出 YES 如果驗證非法:輸出 NOSample Input
.a@b.com pku@edu.cn cs101@gmail.com cs101@gmailSample Output
NO YES YES NO本題原本不難,結果因為讀題及對題意理解不清,導致被卡了很久。
首先說理解誤區,原題說的是'@'不能和'.'直接相連,然而只考慮了@.這種相鄰的情況,而忽視了。@這種相鄰的情況,(實力打臉……)。
剩余的問題就是按照其要求尋找不符合的情況,開始用的直接輸出,不過在卡住之后又換成了使用flag來標記,最后統一輸出,避免在判斷后會有重復輸出的問題(因為不能直接用return來結束程序)。
代碼如下:
#include <stdio.h> #include <string.h> int main (void) {char mail[101];int i, x, y, flag, len, flag_1;while(scanf("%s", mail) != EOF){x = 0;y = 0;flag = 0;//標記是否存在'@'flag_1 = 0;//標記是否輸出'NO'len = strlen(mail);if(mail[0] == '@' || mail[0] == '.' || mail[len-1] == '@' || mail[len-1] == '.'){flag_1 = 1;}/*遇到第一個'@'即停止*/for(i = 0; i < len; i++){if(mail[i] == '@'){x++;//'@'的個數flag = 1;if(mail[i+1] == '.'){flag_1 = 1;}break;}if(mail[i] == '.'){flag = 1;if(mail[i+1] == '@'){flag_1 = 1;}break;}}/*查找'@'之后'.'的個數*/for(i++; i < len && flag; i++){if(mail[i] == '.'){y++;}if(mail[i] == '@')x++;}if(x != 1 || !y){//'@'不唯一 或 '@'后不存在'.'flag_1 = 1;}if(flag_1){printf("NO\n");}else{printf("YES\n");}}return 0; }總結
以上是生活随笔為你收集整理的邮箱验证 ——ACM的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 打算做试管婴儿强阳性结核菌素
- 下一篇: Lowest Common Multip