上午刚刚打过contest14,最后一题滑动窗口均值需要用vector,这里顺便总结下vector内容。
创建容器:
vector // 创建一个空的vector。
vector c1(c2) // 复制一个vector
vector c(n) // 创建一个vector,含有n个数据,数据均已缺省构造产生
vector c(n, elem) // 创建一个含有n个elem拷贝的vector
vector c(beg,end) // 创建一个含有n个elem拷贝的vector
c.~vector () // 销毁所有数据,释放内存
容器内数据操作:
c.assign(beg,end)c.assign(n,elem) //将[beg; end)区间中的数据赋值给c。将n个elem的拷贝赋值给c。
c.at(idx) //传回索引idx所指的数据,如果idx越界,抛出out_of_range。
c.back() // 传回最后一个数据,不检查这个数据是否存在。
c.begin() // 传回迭代器中的第一个数据地址。
c.capacity() // 返回容器中数据个数。
c.clear() // 移除容器中所有数据。
c.empty() // 判断容器是否为空。
c.end() // 指向迭代器中末端元素的下一个,指向一个不存在元素。
c.erase(pos) // 删除pos位置的数据,传回下一个数据的位置。
c.erase(beg,end) //删除[beg,end)区间的数据,传回下一个数据的位置。
c.front() //传回第一个数据。
c.insert(pos,elem) // 在pos位置插入一个elem拷贝,传回新数据位置。
c.insert(pos,n,elem) // 在pos位置插入n个elem数据。无返回值。
c.insert(pos,beg,end) // 在pos位置插入在[beg,end)区间的数据。无返回值。
容器间操作
c.max_size() // 返回容器中最大数据的数量。
c.pop_back() // 删除最后一个数据。
c.push_back(elem) // 在尾部加入一个数据。
c.rbegin() // 传回一个逆向队列的第一个数据。
c.rend() // 传回一个逆向队列的最后一个数据的下一个位置。
c.resize(num) // 重新指定队列的长度。
c.reserve() // 保留适当的容量。
c.size() // 返回容器中实际数据的个数。
c1.swap(c2)
swap(c1,c2) // 将c1和c2元素互换。同上操作。
下面是第三题标解,看起来稍微有点费劲,就加了点注释:
class Solution {
public:
int lengthOfLongestSubstring(string s) {
int maxlen=0,start=-1;
vector<int> dict(256,-1);
for(int i=0;i<s.length();i++){
if(dict[s[i]]>start) //仅有之前发生过标记的位置才会有这种情况
start=dict[s[i]]; //将起始标记改为之前标记的位置
dict[s[i]]=i;
maxlen=max(maxlen,i-start); //start代表当前位置对应的最长子序列头部位置
}
return maxlen;
}
};
自己超时的解法,感觉一个是memset的锅,另一个是累加太费时间,另外感觉正确性有点问题,有一个概念应该明确的是,每位字符都对应一个最长不重复子序列,这个开头都是需要单独记录的:
class Solution {
public:
int lengthOfLongestSubstring(string s) {
int countx[10000];
int sign[128],x;
int lenth,last=0;
int maxlen=0;
lenth=s.length();
for(int i=0;i<lenth;i++)
{
if(sign[s[i]]!=0){
last=i;
for(int j=0;j<128;j++){
sign[j]=0;
}
}
else{
countx[last]++;
sign[s[i]]=1;
}
}
for(int i=0;i<lenth;i++){
if(countx[i]>maxlen){
maxlen=countx[i];
}
}
return maxlen;
}
};
附带一个测试用的主函数:
int main()
{
string s;
cin >> s;
int ans;
Solution solu;
ans=solu.lengthOfLongestSubstring(s);
cout<<ans<<endl;
return 0;
}