首页 > 代码库 > HDU5007Post Robot
HDU5007Post Robot
题目:HDU5007Post Robot
题目大意:给你一段字符,如果你碰到“Apple”, “iPhone”, “iPod”, “iPad”就输出“MAI MAI MAI!”,如果碰到Sony,就输出“SONY DAFA IS GOOD!” 。注意大小写敏感。
解题思路:字符串遍历。
代码:
#include <cstdio> #include <cstring> const int maxn = 1e4 + 5; const char *s1 = "MAI MAI MAI!"; const char *s2 = "SONY DAFA IS GOOD!"; char str[maxn]; int len; bool is_sony (int k) { if (k + 3 >= len) return false; if (str[k] == 'S' && str[k + 1] == 'o' && str[k + 2] == 'n' && str[k + 3] == 'y') return true; return false; } bool is_apple (int k) { if (k + 4 >= len) return false; if (str[k] == 'A' && str[k + 1] == 'p' && str[k + 2] == 'p' && str[k + 3] == 'l' && str[k + 4] == 'e') return true; return false; } bool is_iphone (int k) { if (k + 5 >= len) return false; if (str[k] == 'i' && str[k + 1] == 'P' && str[k + 2] == 'h' && str[k + 3] == 'o' && str[k + 4] == 'n' && str[k + 5] == 'e') return true; return false; } bool is_ipod (int k) { if (k + 3 >= len) return false; if (str[k] == 'i' && str[k + 1] == 'P' && str[k + 2] == 'o' && str[k + 3] == 'd') return true; return false; } bool is_ipad (int k) { if (str[k] == 'i' && str[k + 1] == 'P' && str[k + 2] == 'a' && str[k + 3] == 'd') return true; return false; } int main () { while (gets (str) != NULL) { len = strlen (str); for (int i = 0; i < len; i++) { if (str[i] == 'A' && is_apple(i)) { printf ("%s\n", s1); i += 4; } else if (str[i] == 'S' && is_sony(i)) { printf ("%s\n", s2); i += 3; } else if (str[i] == 'i') { if (is_iphone(i)) { printf ("%s\n", s1); i += 5; } else if (is_ipod(i)) { printf ("%s\n", s1); i += 3; } else if (is_ipad(i)) { printf ("%s\n", s1); i += 3; } } } } return 0; }
HDU5007Post Robot
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。