find()函數及其他常用函數總結

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

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章