【分治】化装晚会
2017-07-25 18:34
120 查看
题目描述
万圣节又到了!FJ打算带他的奶牛去参加化装晚会,但是,FJ只做了一套能容下两头总长不超过S (1≤S≤1000000)的奶牛恐怖服装。FJ养了N(2≤N≤20000)头按1--N顺序编号的奶牛,编号为i的奶牛的长度为L_i(1≤L_i≤1000000)。如果两头奶牛的总长度不超过S,那么她们就能穿下这套服装。
FJ想知道,如果他想选择两头不同的奶牛来穿这套衣服,一共有多少种满足条件的方案。
输入
第1行是2个整数:N和S;
第2~N+l行每行一个整数:L_i。
输出
1个整数,表示FJ可选择的所有方案数。注意奶牛顺序不同的两种方案是被视为相同的。
样例输入
4 6
3
5
2
1
样例输出
4
提示
样例说明:4种选择分别为:奶牛1和奶牛3;奶牛l和奶牛4;奶牛2和奶牛4;奶牛3和奶牛4
#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#include <cmath>
#include <algorithm>
#include <vector>
#include <map>
#include <string>
#include <stack>
#define LL long long
#define INF 0x7fffffff
#define MAX 20005
#define PI 3.1415926535897932
#define E 2.718281828459045
using namespace std;
int n,s;
int a[MAX];
int main()
{
scanf("%d%d",&n,&s);
for(int i=1;i<=n;i++)
scanf("%d",&a[i]);
sort(a+1,a+n+1);
int sum=0;
for(int i=1;i<=n;i++)
{
int r=n,l=i;
while (a[l]+a[r]>s && r>l)
r--;
sum+=(r-l);
}
printf("%d\n",sum);
return 0;
}
万圣节又到了!FJ打算带他的奶牛去参加化装晚会,但是,FJ只做了一套能容下两头总长不超过S (1≤S≤1000000)的奶牛恐怖服装。FJ养了N(2≤N≤20000)头按1--N顺序编号的奶牛,编号为i的奶牛的长度为L_i(1≤L_i≤1000000)。如果两头奶牛的总长度不超过S,那么她们就能穿下这套服装。
FJ想知道,如果他想选择两头不同的奶牛来穿这套衣服,一共有多少种满足条件的方案。
输入
第1行是2个整数:N和S;
第2~N+l行每行一个整数:L_i。
输出
1个整数,表示FJ可选择的所有方案数。注意奶牛顺序不同的两种方案是被视为相同的。
样例输入
4 6
3
5
2
1
样例输出
4
提示
样例说明:4种选择分别为:奶牛1和奶牛3;奶牛l和奶牛4;奶牛2和奶牛4;奶牛3和奶牛4
#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#include <cmath>
#include <algorithm>
#include <vector>
#include <map>
#include <string>
#include <stack>
#define LL long long
#define INF 0x7fffffff
#define MAX 20005
#define PI 3.1415926535897932
#define E 2.718281828459045
using namespace std;
int n,s;
int a[MAX];
int main()
{
scanf("%d%d",&n,&s);
for(int i=1;i<=n;i++)
scanf("%d",&a[i]);
sort(a+1,a+n+1);
int sum=0;
for(int i=1;i<=n;i++)
{
int r=n,l=i;
while (a[l]+a[r]>s && r>l)
r--;
sum+=(r-l);
}
printf("%d\n",sum);
return 0;
}
相关文章推荐
- USACO/costume/化装晚会 [Neal Wu, 2007]
- 化装晚会
- Problem B:化装晚会(usaco月赛)
- [USACO Jan08] 化装晚会
- 【二分】COGS 140. [USACO Jan08] 化装晚会
- 化装晚会
- 化装晚会(costume)
- The Closest Pair Problem uva+分治
- hdu 4871 Shortest-path tree(最短路+点分治)
- 树链剖分-点的分治(点数为k且距离最长的点对)
- hdu 4911 Inversion (分治 归并排序 求逆序数)
- TOJ 4095 BoatBurglary 分治
- [递归与分治]棋盘覆盖问题
- hdu 4918 Query on the subtree(树分治 + 树状数组)
- UvaLive 6667 Longest Chain (分治求三维LIS)
- hdu 4812 树分治
- SPOJ1825 Free tour II 树分治
- 分治 求点对最短距离 hdu 1007 Quoit Design
- BZOJ 2152 聪聪可可 树的点分治/树形DP
- 求最大子数组的和,算法导论之分治递归求解,暴力求解,记忆扫描方法。