一:find()函数:
第一种,algorithm头文件的find()。
使用方法:find(begin,end,value),一般用 容器.end()来判断查找成功与否。
参数1 是容器或者数组的起始地址(容器.begin()或者数组名),也可以是任意地址,不非法即可;
参数2是结束查找的地址(容器.end()或者数组名+长度),value是想要查找的字符或者字符串
查找成功将返回迭代器(容器)或者指针(数组),否则返回end()
#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
int main()
{
vector<int> v;
for(int i=0;i<5;i++){
v.push_back(i);
}
if(find(v.begin(),v.end(),4)!=v.end()){
printf("找到的下标为%d\n",find(v.begin(),v.end(),4)-v.begin()); //获取元素的下标
}else{
printf("该元素不存在\n");
}
return 0;
}
第二种,string自带的find(),可查找指定字符串和指定字符。
使用方法:如在string1中查找string2,string1.find(string2);返回值为string2第一次在string1中出现的位置。
若希望在特定位置开始查找,可使用 string1.find(string2,location);
如果找不到,则返回值为string::npos ,即对于string,通过a.find(val)==string::npos来做判断是否查找成功
#include<iostream>
#include<string>
using namespace std;
int main()
{
string s1,s2;
s1 = "hello world";
s2 = "world";
if(s1.find(s2)!=string::npos){ //查找字符串
printf("s2在s1中的起始下标为%d\n",s1.find(s2));
}else{
printf("s1中不存在s2字符串");
}
char c = 'e';
if(s1.find(c)!=string::npos){ //查找字符
printf("字符c在s1中的起始下标为%d\n",s1.find(c));
}else{
printf("s1中不存在字符c");
}
return 0;
}
二:max()、min()函数
#include<iostream>
using namespace std;
int main()
{
int a,b;
cout<<"输入数据:";
cin>>a>>b;
cout<<"最大者是"<<max(a,b)<<endl; //获取两数中的最大者
cout<<"最小者是"<<min(a,b)<<endl; //获取两数中的最小者
return 0;
}
三:atoi()函数,把字符串转换成整型数
头文件: #include <stdlib.h>
对于字符数组
#include<iostream>
#include<algorithm>
using namespace std;
int main()
{
char str[10] = "12345";
int n = atoi(str);
printf("n = %d\n",n);
return 0;
}
对于string类型的字符串,需要调用c_str()函数转换为字符数组后才能作为参数转换
#include<iostream>
#include<algorithm>
#include<string>
using namespace std;
int main()
{
string s = "12345";
int n = atoi(s.c_str());
printf("n = %d\n",n);
return 0;
}