1307 - Counting Triangles
| Time Limit: 2 second(s) | Memory Limit: 32 MB |
You are given N sticks having distinct lengths; you have to form some triangles using the sticks. A triangle is valid if its area is positive. Your task is to find the number of ways you can form a valid triangle using the sticks.
Input
Input starts with an integer T (≤ 10), denoting the number of test cases.
Each case starts with a line containing an integer N (3 ≤ N ≤ 2000). The next line contains N integers denoting the lengths of the sticks. You can assume that the lengths are distinct and each length lies in the range [1, 109].
Output
For each case, print the case number and the total number of ways a valid triangle can be formed.
Sample Input |
Output for Sample Input |
|
3 5 3 12 5 4 9 6 1 2 3 4 5 6 4 100 211 212 121 |
Case 1: 3 Case 2: 7 Case 3: 4 |
1 #include<stdio.h>
2 #include<algorithm>
3 #include<iostream>
4 #include<string.h>
5 #include<queue>
6 #include<stdlib.h>
7 #include<math.h>
8 #include<stack>
9 #include<vector>
10 #include<map>
11 using namespace std;
12 typedef long long LL;
13 int ans[2005];
14 typedef struct pp
15 {
16 short int x;
17 short int y;
18 } ss;
19 ss ak[4000005];
20 int main(void)
21 {
22 int i,j,k;
23 scanf("%d",&k);
24 int s;
25 for(s=1; s<=k; s++)
26 {
27 int n,m;
28 scanf("%d",&n);
29 for(i=0; i<n; i++)
30 {
31 scanf("%d",&ans[i]);
32 }
33 sort(ans,ans+n);
34 int cnt=0;
35 for(i=0; i<n; i++)
36 {
37 for(j=i+1; j<n; j++)
38 {
39 ak[cnt].x=i;
40 ak[cnt].y=j;
41 cnt++;
42 }
43 }
44 LL sum=0;
45 for(i=0; i<cnt; i++)
46 {
47 int l=0;
48 int r=n-1;
49 int maxx=max(ans[ak[i].x],ans[ak[i].y]);
50 int minn=min(ans[ak[i].x],ans[ak[i].y]);
51 int id=0;
52 l=0;
53 r=n-1;int id1=-1;
54 while(l<=r)
55 {
56 int mid=(l+r)/2;
57 if(ans[mid]+minn>maxx)
58 {
59 id1=mid;
60 r=mid-1;
61 }
62 else l=mid+1;
63 }
64 l=0;
65 r=n-1;int id2=-1;
66 while(l<=r)
67 {
68 int mid=(l+r)/2;
69 if(ans[mid]<maxx+minn)
70 {
71 id2=mid;
72 l=mid+1;
73 }
74 else r=mid-1;
75 }
76 if(id1!=id2)
77 {
78 sum+=id2-id1+1;
79 if(ak[i].x>=id1&&ak[i].x<=id2)
80 sum--;
81 if(ak[i].y<=id2&&ak[i].y>=id1)
82 sum--;
83 }
84 }
85 printf("Case %d: ",s);
86 printf("%lld\n",sum/3);
87 }
88 return 0;
89 }
1307 - Counting Triangles的更多相关文章
- hdu 1396 Counting Triangles(递推)
Counting Triangles Problem Description Given an equilateral triangle with n thelength of its side, p ...
- Counting Triangles(hd1396)
Counting Triangles Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
- UVA 12075 - Counting Triangles(容斥原理计数)
题目链接:12075 - Counting Triangles 题意:求n * m矩形内,最多能组成几个三角形 这题和UVA 1393类似,把总情况扣去三点共线情况,那么问题转化为求三点共线的情况,对 ...
- LA 3295 (计数 容斥原理) Counting Triangles
如果用容斥原理递推的办法,这道题确实和LA 3720 Highway很像. 看到大神们写的博客,什么乱搞啊,随便统计一下,这真的让小白很为难,于是我决定用比较严格的语言来写这篇题解. 整体思路很简单: ...
- UVALive 3295 Counting Triangles
题目链接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_ ...
- UVA 12075 Counting Triangles
https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- UVA 1393 Highways,UVA 12075 Counting Triangles —— (组合数,dp)
先看第一题,有n*m个点,求在这些点中,有多少条直线,经过了至少两点,且不是水平的也不是竖直的. 分析:由于对称性,我们只要求一个方向的线即可.该题分成两个过程,第一个过程是求出n*m的矩形中,dp[ ...
- Codestorm:Counting Triangles 查各种三角形的个数
题目链接:https://www.hackerrank.com/contests/codestorm/challenges/ilia 这周六玩了一天的Codestorm,这个题目是真的很好玩,无奈只做 ...
- HDUOJ-Counting Triangles
Counting Triangles Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Other ...
随机推荐
- LATEX公式语法
see how any formula was written in any question or answer, including this one, right-click on the ex ...
- UE4之Slate:纯C++工程配置
概述: Slate是UE4提供的UI框架,整个UE4 Editor UI都是使用Slate构建的: Slate的官方文档:[Slate UI框架] Slate底层内容,中文环境下能搜索到的有效资源也不 ...
- 百页 PPT BPF 技术全览 - 深入浅出 BPF 技术
eBPF 从创建开始,短短数年(7年),至今就已经被认为是过去 50 年来操作系统最大的变更,那么 eBPF 技术到底给我们带来了什么样的超能力,以至于得到如此高的评价? 本文从以下内容入手,对 eB ...
- A Child's History of England.25
It was a September morning, and the sun was rising, when the King was awakened from slumber by the s ...
- A Child's History of England.35
The other two clung to the yard for some hours. At length the young noble said faintly, 'I am exhaus ...
- CSS相关,手画三角形,正方形,扇形
三角形 实现一个三角形 <!DOCTYPE html> <html> <head> <title>三角形</title> <style ...
- 【STM32】基于正点原子『探索者』开发板的烧录
项目需要一个功能,开发板范例正好有,就买了一块,不过还是有点贵 我手边没有J-Link 用的都是串口烧录 烧录时,先打开右上的开关 如果是仿真器烧录,它无法供电,需要接12V适配器或是杜邦线供电 然后 ...
- Shell变量与算术运算
区分两个 Shell Shell 语言与 Shell 解释器 Shell 语言 写 Shell 脚本使用的是 Shell 语言,Shell 既是一种命令语言,又是一种程序设计语言. 作为命令语言,它交 ...
- 数据库SQL性能优化
1.in与exists的效率比较 in是把外表和内表作hash 连接,而exists 是对外表作loop 循环,每次loop 循环再对内表进行查询.一直以来认为exists 比in 效率高的说法是不准 ...
- Linux基础命令---nslookup查询域名工具
nslookup nslookup是一个查询DNS域名的工具,它有交互和非交互两种工作模式. 此命令的适用范围:RedHat.RHEL.Ubuntu.CentOS.Fedora. 1.语法 ...