排序与查找
1、对输入的n个数进行排序并输出
第一行输入个数n,下一行输入n个整数。
<注意>
- sort函数用法:#include < algorithm> && sort(起始地址, 终止地址, compare1);
第三个参数不写时默认是升序,可以写个函数,里面是复杂的排序规则
降序示例:bool compare1(int a, int b){ return a>b;} - for循环中++i与i++:在用法上没有什么大的差别,但++i运行会更快,因为i++需要一个临时变量取存储返回自增前的值,而++i不需要。因此可以多用++i。
#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;
int main(){
int n;
int num[100];
while(scanf("%d",&n)!=EOF){
for(int i=0;i<n;++i){
scanf("%d",&num[i]);
}
sort(num,num+n);
for(int i=0;i<n;++i){
printf("%d ",num[i]);
}
printf("\n");
}
return 0;
}
2、用一维数组存储学号和成绩,然后按成绩排序输出
输入:第一行一个整数N,代表学生个数
接下来N行每行两个整数p,q代表学号和成绩。
输出:按学生成绩从小到大排序,成绩相同时按学号排序。
<注>用到了结构体和sort自定义比较函数
#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;
struct Student{
int num;
int score;
};
Student stu[100];
bool compare1(Student s1,Student s2){
if(s1.score==s2.score)
return s1.num<s2.num;
else
return s1.score<s2.score; //记忆方法:想要的序列长什么样子就返回什么样子
}
int main(){
int n;
while(scanf("%d",&n)!=EOF){
for(int i=0;i<n;++i){
scanf("%d",&stu[i].num);
scanf("%d",&stu[i].score);
}
sort(stu,stu+n,compare1);
for(int i=0;i<n;++i){
printf("%d %d\n",stu[i].num,stu[i].score);
}
}
return 0;
}
第三题:输入任意(用户,成绩)序列,按成绩从高到低或从低到高排序,相同成绩时,先录入者在前。
大体和第二题一样,就是多了个可以选升序降序。
然后字符串的输入输出要记一下。cin>>、 cout<<、 endl换行
#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;
struct Student{
string name;
int score;
int timesq;
};
bool compare1(Student s1,Student s2){
if(s1.score==s2.score)
return s1.timesq<s2.timesq;
else
return s1.score<s2.score;
}
bool compare2(Student s1,Student s2){
if(s1.score==s2.score)
return s1.timesq<s2.timesq;
else
return s1.score>s2.score;
}
int main(){
int n;
int choice;
while(scanf("%d",&n)!=EOF){
Student stu[n];
scanf("%d",&choice);
for(int i=0;i<n;++i){
cin>>stu[i].name>>stu[i].score;
stu[i].timesq=i;
}
if(choice==0){
sort(stu,stu+n,compare2);
printf("从高到低排序:\n");
}
if(choice==1){
sort(stu,stu+n,compare1);
printf("从低到高排序:\n");
}
for(int j=0;j<n;++j){
cout<<stu[j].name<<" "<<stu[j].score<<endl;
}
}
return 0;
}
第四题:输入一个数n,然后输入n个不同的值,输出这个值在数组中的下标(不在数组中输出-1)
#include <iostream>
#include <cstdio>
using namespace std;
int main(){
int n;
int num[200];
while(scanf("%d",&n)!=EOF){
int x;
int find=-1;
for(int i=0;i<n;++i){
scanf("%d",&num[i]);
}
scanf("%d",&x);
for(int j=0;j<n;++j){
if(num[j]==x){
find=j;
break;
}
}
printf("%d\n",find);
}
return 0;
}
第五题:输入数组长度n,输入n个整数,输入查找次数m,输入m个查找数字,找到输出YES,没有输出NO
<注>主要是看二分查找,它在数比较多时效率更高,但需要先排序。
#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;
int num[100];
//介绍二分查找
bool BinarySearch(int n,int target){
int left=0;
int right=n-1;
while(left<=right){
int middle=(left+right)/2;
if(num[middle]<target){
left=middle+1;
}
else if(num[middle]>target){
right=middle-1;
}
else{
return true;
}
}
return false;
}
int main(){
int n,m;
while(scanf("%d",&n)!=EOF){
for(int i=0;i<n;++i){
scanf("%d",&num[i]);
}
sort(num,num+n);//默认升序
scanf("%d",&m);
for(int i=0;i<m;i++){
int target;
scanf("%d",&target);
if(BinarySearch(n,target)){
printf("YES\n");
}
else{
printf("NO\n");
}
}
}
return 0;
}