机试练习第四天

排序与查找
1、对输入的n个数进行排序并输出
第一行输入个数n,下一行输入n个整数。
<注意>

  1. sort函数用法:#include < algorithm> && sort(起始地址, 终止地址, compare1);
    第三个参数不写时默认是升序,可以写个函数,里面是复杂的排序规则
    降序示例:bool compare1(int a, int b){ return a>b;}
  2. 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;
} 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值