华为机试题刷题笔记

1.一段英文字符串中最后一个单词的长度:
注意要点:cin和getline的区别;
cin为字符串输入时,遇见空格,编译器认为字符串输入结束;
getline可以输入含有空格的字符串;
安全起见,在C++中字符串的输入,最好都用getline;
cin作为输入字符串的例子如下图所示:结果输出的字符串为输入第一个空格之前的数据;
华为机试题刷题笔记_第1张图片
运行结果:
华为机试题刷题笔记_第2张图片
本机试题代码:

#include
#include
#include
using namespace std;
int main(){
 int i;
 int count=0;
 string str;
 getline(cin,str);
 i=str.size()-1;
 while(str[i]!=' '&&i>=0){
  count++;
  i--;
 }
 cout<<"本句子最后一个单词的长度为:"<

运行结果:
华为机试题刷题笔记_第3张图片
2.输入一个字符串和一个字符,统计该字符在该字符串中出现的次数:
注意点:只要是一个字母就行,不区分大小写;
需要用到tolower函数;
代码:

#include
#include
#include
using namespace std;
int main(){
 string str;
 int count,i;
 char ch;
 count=0;
 getline(cin,str);
 cin>>ch;
 for(i=str.size()-1;i>=0;i--){
  if(tolower(str[i])==tolower(ch)){
   count++;
  }
 }
 cout<

华为机试题刷题笔记_第4张图片
3.输入一串整数,整数去重,输出排好序的结果:
学习要点:sort和unique函数的用法;
版本一:
不用任何库函数;
冒泡排序加排序后比较重复数字进行剔除

#include
#include
using namespace std;
int main(){
	int n;//数组长度
	int *arr;
	cout<<"请输入该数组的长度:"<>arr[i];
	}
	//冒泡排序
	for(i=1;iarr[j+1]){
				int temp=arr[j];
				arr[j]=arr[j+1];
				arr[j+1]=temp;
			}
		}
	}
	//去重
	for(int i=0;i

运行结果
在这里插入图片描述
版本二:
利用容器里面的set的特点,不重复且排好序;
代码:

#include
#include
#include
using namespace std;
int main(){
	int n;//数组大小
	cout<<"请输入数组长度:"<>n){
		set arr;
		for(int j=0;j::iterator iter=arr.begin();iter!=arr.end();iter++){
			cout<<*iter<<' ';
		}
		cout<

运行结果:
华为机试题刷题笔记_第5张图片
版本三:
主要是利用了sort函数和unique函数;
sort(itera,iterb),对迭代器表示的地址之间的数值进行从小到大的排序;默认从小到大;
unique函数的用法:
功能:对有序的容器重新排序,将第一次出现的元素从前往后排,其他重复出现的元素依次排在后面;
返回值:返回迭代器;指向重复元素的首地址
华为机试题刷题笔记_第6张图片
erase函数:
erase(itera,iterb)
擦除从迭代器a到迭代器b之间的元素;
代码:

#include
#include
#include
#include
using namespace std;
int main(){
	int n;
	cout<<"请输入数组长度:"<>n){
		vector arr;
		for(int i=0;i>temp;
			arr.pushback(temp);
		}
		sort(arr.begin(),arr.ennd());
		vectoriterator::iter;
		iter=unique(arr.begin().arr.end());
		if(iter!=arr.end()){
			arr.erase(iter,arr.end())
		}
		for(iter=arr.begin();iter!=arr.end();iter++){
			cout<<*iter<

华为机试题刷题笔记_第7张图片

你可能感兴趣的:(C++,homework)