茂名网站建设服务,网络营销存在的问题及解决对策,衡水网站建设哪家专业,国外网站为什么不用备案题目链接#xff1a;https://leetcode.cn/problems/linked-list-components/description/
题目大意#xff1a;给出一个vectorint nums#xff0c;其中有一些数字。再给出一个链表的头指针head#xff0c;链表内的元素各不相同。如果链表中有某一段#xff08;长…题目链接https://leetcode.cn/problems/linked-list-components/description/
题目大意给出一个vectorint nums其中有一些数字。再给出一个链表的头指针head链表内的元素各不相同。如果链表中有某一段长度大于等于1的元素都在nums中出现过那么就算一个component求链表中的component的个数。
思路【判断是否在nums中出现过】直接用set就好了如果是STL的话用count方法很方便。不过测试了一下后发现时间花得有点多于是换成了数组。
使用两个布尔值last表示【上一个元素】【是否在nums中出现过】用flag表示【当前元素】【是否在nums中出现过】
当last false flag true时说明出现了一个新的component结果加一当last true flag false时说明出现了当前的component结束了在判断之后都需要更新last
完整代码
class Solution {
public:int numComponents(ListNode* head, vectorint nums) {bool nm[10001] {0};for (auto x : nums) {nm[x] true;}ListNode* ptr head;bool last false;int ret 0;while (ptr) {bool flag nm[ptr-val];if (flag ! last) {if (last) {last false;}else {ret;last true;}}ptr ptr-next;}return ret;}
};