为什么在这里pos会等于1,该如何解决

为什么在这里pos会等于1
int main(){
string str = "ab2c3d7r4e6";
string number = "0123456789";
string letter = "abcdefghijklmnopqrstuvwsyz ABCDEFGHIJKLMNOPQRSTUVWSYZ";
//寻找出所有数字的位置
string::size_type p = 0;
while(p = str.find_first_of(number,p) && p != string::npos){
cout << "在字符串的第" << p+1 << "是数字" << str[p] << " ";
++p;
}
//找出所有字母
p = 0;
while(p = str.find_first_of(letter, p) && p != string::npos){
cout << "在字符串的第" << p+1 << "是字符" << str[p] << " "; 
++p;
}
return 0;
}

while(p = str.find_first_of(number,p) && p != string::npos)
这里p等于1不知道为什么~~我单独p = str.find_first_of(number,p)然后cout << p;是输出2没错~~可是在while里面他就是等于1~~为什么?

------解决方案--------------------
特来蹭分+帮楼主结帖(^_^)

不要使用
while (条件)
更不要使用
while (组合条件)
要使用
while (1) {
 if (条件1) break;
 //...
 if (条件2) continue;
 //...
 if (条件3) return;
 //...
}
因为前两种写法在语言表达意思的层面上有二义性,只有第三种才忠实反映了程序流的实际情况。
典型如:
下面两段的语义都是当文件未结束时读字符
whlie (!feof(f)) {
 a=fgetc(f);
 //...
 b=fgetc(f);//可能此时已经feof了!
 //...
}
而这样写就没有问题:
whlie (1) {
 a=fgetc(f);
 if (feof(f)) break;
 //...
 b=fgetc(f);
 if (feof(f)) break;
 //...
}
类似的例子还可以举很多。

------解决方案--------------------
while((p = str.find_first_of(number,p)) && p != string::npos)