zoukankan      html  css  js  c++  java
  • Codeforces Round #544 (Div. 3) C. Balanced Team [暴力剪枝]

    You are a coach at your local university. There are
    n
    n
    students under your supervision, the programming skill of the
    i
    i
    -th student is
    a
    i
    ai
    .
    You have to create a team for a new programming competition. As you know, the more students some team has the more probable its victory is! So you have to create a team with the maximum number of students. But you also know that a team should be balanced. It means that the programming skill of each pair of students in a created team should differ by no more than
    5
    5
    .
    Your task is to report the maximum possible number of students in a balanced team.
    Input
    The first line of the input contains one integer
    n
    n
    (
    1≤n≤2⋅
    10
    5
    1≤n≤2⋅105
    ) — the number of students.
    The second line of the input contains
    n
    n
    integers
    a
    1
    ,
    a
    2
    ,…,
    a
    n
    a1,a2,…,an
    (
    1≤
    a
    i

    10
    9
    1≤ai≤109
    ), where
    a
    i
    ai
    is a programming skill of the
    i
    i
    -th student.
    Output
    Print one integer — the maximum possible number of students in a balanced team.
    Examples
    Input
    Copy
    6
    1 10 17 12 15 2
    Output
    Copy
    3
    Input
    Copy
    10
    1337 1337 1337 1337 1337 1337 1337 1337 1337 1337
    Output
    Copy
    10
    Input
    Copy
    6
    1 1000 10000 10 100 1000000000
    Output
    Copy
    1

    题解:题意给n个数,求子集的最小值和最大值之差不超过5,求最大的子集的元素数.
    我的思路:先对数组排序,这里如果直接暴力的话,O(n^2)的复杂度,肯定会tle,
    优化一下,因为是排过序的,所以子集的左端和右端都是极值,如果右值与左值之差大于5,左值的位置右移,

    再次优化,如果前一值与后一值之差大于5,I 移动的后一值的位置.

    #include <bits/stdc++.h>
    const int N=2e5+5;
    using namespace std;
    int a[N],b[N];
    int ans=0,cnt=0,flag=0,maxn=0;
    void check(int m){
    	if(m>maxn) maxn=m;
    }
    int cal(int i,int j){
    	return a[j]-a[i];
    }
    int main(){
    	int n;
    	scanf("%d",&n);
    	for(int i=1;i<=n;i++){
    		scanf("%d",&a[i]);
    	}
    	sort(a+1,a+1+n);
    	int i=1,j=i+1;
    	while(i<=n-1&&j<=n){
    		if(cal(j-1,j)>5){
    			check(j-1-i);
    			i=j;
    			j++;
    		}
    		else if(cal(i,j)>5){
    			check(j-1-i);
    			i++;
    			if(i==j) j++;
    			//cout<<"jjg"<<endl;
    		}
    		else{
    			j++;
    			//cout<<"jj"<<endl;
    		}
    		//if(!flag) break;
    	}
    	check(j-1-i);
    	printf("%d
    ",maxn+1);
    	return 0;
    }
    
  • 相关阅读:
    C#中调用DTS
    经典问题:向setTimeout传递函数参数
    C#.NET 中的类型转换
    SQL语句导入导出大全 (转载)
    js脚本defer的作用
    [转]使用 Java API 处理 WebSphere MQ 大消息
    WideCharToMultiByte 宽字节转换为多字节
    [原].NET数据库开发中请注意区域时间格式
    输出页眉和页脚的简单HTTP模块实践
    浅析ASP.NET HTTP Module
  • 原文地址:https://www.cnblogs.com/-yjun/p/10503477.html
Copyright © 2011-2022 走看看