一: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;
}