c++ - 【LeetCode】Word Pattern
问题描述
我在 LeetCode 上练习 Word Pattern(题目连接点这里),写的程序放在本地VS2008上跑如下实例:
pattern = 'abba', str = 'dog cat cat fish' should return false.
没有问题,返回的是false,但是放在LeetCode 上提交,提示错误,错误如下:
代码如下:
class Solution {public: bool wordPattern(string pattern, string str) {const int len = pattern.length();char * c = new char[len+1];strcpy(c, pattern.c_str() );char * arr[1024];int num = 0;char * pch;pch = strtok(c, ' ');while (pch != NULL){ arr[num++] = pch; pch = strtok(NULL, ' ');}vector<char> vecStr;vector<char *> vecPattern;for (int i = 0; i < num; ++i){ for (int j = 0; j < vecStr.size(); ++j) {if (vecStr[j] == str[i] && *(vecPattern[j]) != *(arr[i]) ){ return false;} } for (int j = 0; j < vecPattern.size(); ++j) {if (*(vecPattern[j]) == *(arr[i]) && vecStr[j] != str[i]){ return false;} } vecStr.push_back(str[i]); vecPattern.push_back(arr[i]);}return true; }};
求指教。
问题解答
回答1:我拿你的代码运行了一下发现就是错的呀。为什么呢,因为
pch = strtok(c, ' '); while (pch != NULL) {arr[num++] = pch;pch = strtok(NULL, ' '); }
这里你的c本来应该是str,你却指向了pattern。
而且我觉得你写到后面pattern和str可能在你脑子里已经乱掉了,你还得接着往下改。
相关文章:
1. 如何解决docker宿主机无法访问容器中的服务?2. javascript - 微信jssdk ios下自定义onMenuShareAppMessage 分享失效,Android分享成功3. 老师百度网盘分享一下WampServer的包啊,我们下载几kb要下载一天的.4. java - 如图,同样一个表单,为什么用myeclipse内置的浏览器提交就会自动编码,用chrome浏览器就不会自动编码?5. node.js - windows下安装webpack时出现路径问题如何解决?6. SQLAlchemy 访问Mysql数据库弹出Warning,VARIABLE_VALUE,如何解决?7. php study 安装 composer 用不了8. vue.js - weex 没有背景图片属性怎么办?9. html - css中怎么命名颜色比较好?10. 关于java 泛型设计接口 导致的参数类型不匹配问题
