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. dockerfile - 我用docker build的时候出现下边问题 麻烦帮我看一下2. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””3. docker - 如何修改运行中容器的配置4. docker不显示端口映射呢?5. nignx - docker内nginx 80端口被占用6. docker - 各位电脑上有多少个容器啊?容器一多,自己都搞混了,咋办呢?7. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!8. mac连接阿里云docker集群,已经卡了2天了,求问?9. 网页爬虫 - python爬虫翻页问题,请问各位大神我这段代码怎样翻页,还有价格要登陆后才能看到,应该怎么解决10. golang - 用IDE看docker源码时的小问题