题目描述

给出圆周上的若干个点,已知点与点之间的弧长,其值均为正整数,并依圆周顺序排列。 请找出这些点中有没有可以围成矩形的,并希望在最短时间内找出所有不重复矩形。

输入输出格式

输入格式:

第一行为正整数N,表示点的个数,接下来N行分别为这N个点所分割的各个圆弧长度

输出格式:

所构成不重复矩形的个数

输入输出样例

输入样例#1:
复制

8
1
2
2
3
1
1
3
3
输出样例#1: 复制

3

说明

N<=20

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstdlib>
#include<cstring>
#include<string>
#include<cmath>
#include<map>
#include<set>
#include<vector>
#include<queue>
#include<bitset>
#include<ctime>
#include<deque>
#include<stack>
#include<functional>
#include<sstream>
//#include<cctype>
//#pragma GCC optimize(2)
using namespace std;
#define maxn 200005
#define inf 0x7fffffff
//#define INF 1e18
#define rdint(x) scanf("%d",&x)
#define rdllt(x) scanf("%lld",&x)
#define rdult(x) scanf("%lu",&x)
#define rdlf(x) scanf("%lf",&x)
#define rdstr(x) scanf("%s",x)
typedef long long ll;
typedef unsigned long long ull;
typedef unsigned int U;
#define ms(x) memset((x),0,sizeof(x))
const long long int mod = 1e9 + 7;
#define Mod 1000000000
#define sq(x) (x)*(x)
#define eps 1e-3
typedef pair<int, int> pii;
#define pi acos(-1.0)
//const int N = 1005;
#define REP(i,n) for(int i=0;i<(n);i++)
typedef pair<int, int> pii;
inline ll rd() {
ll x = 0;
char c = getchar();
bool f = false;
while (!isdigit(c)) {
if (c == '-') f = true;
c = getchar();
}
while (isdigit(c)) {
x = (x << 1) + (x << 3) + (c ^ 48);
c = getchar();
}
return f ? -x : x;
} ll gcd(ll a, ll b) {
return b == 0 ? a : gcd(b, a%b);
}
int sqr(int x) { return x * x; } /*ll ans;
ll exgcd(ll a, ll b, ll &x, ll &y) {
if (!b) {
x = 1; y = 0; return a;
}
ans = exgcd(b, a%b, x, y);
ll t = x; x = y; y = t - a / b * y;
return ans;
}
*/ int n;
int a[maxn];
int sum[maxn]; int main() {
//ios::sync_with_stdio(0);
rdint(n);
for (int i = 1; i <= n; i++)rdint(a[i]), sum[i] = sum[i - 1] + a[i];
int ans = 0;
for (int i = 1; i <= n; i++) {
for (int j = i + 1; j <= n; j++) {
if (sum[j] - sum[i] == (sum[n] / 2))ans++;
}
}
cout << ans * (ans - 1) / 2 << endl;
return 0;
}

最新文章

  1. WindowsForm多窗体、多窗体传值、控件数据绑定--2016年12月8日
  2. @overrive报错解决方案
  3. javascript数组 去重
  4. win10使用技巧
  5. 让fetch也可以timeout
  6. 有关于eclipse启动不了的问题
  7. js 根据年月获取当月有多少天_js获取农历日期_及Js其它常用有用函数
  8. 【转载】-- vi/vim使用
  9. mysql如何更改数据库名(一键实现mysql改数据库名)
  10. Andorid 编程 系统环境安装
  11. [ 兼容 ] IE和Firefox的Javascript兼容性总结
  12. iOS 进阶 第二十一天(0531)
  13. 20. atoi函数
  14. python学习笔记6(字典)
  15. php 利用第三方软件进行网页快照
  16. hdu 5066 Harry And Physical Teacher(Bestcoder Round #14)
  17. Zeppelin使用spark解释器
  18. 七牛 在线管理 v0.1
  19. CSS| 學習心得
  20. ArcGis连接oracle、oracle配置

热门文章

  1. QFileInfo与QFileIconProvider(分别用于获取文件信息和获取文件的图标)
  2. codeforces 650 C. Watchmen(数学公式)
  3. bzoj2654tree
  4. Angular Chart 使用说明(基于angular工程)
  5. bzoj 3545: [ONTAK2010]Peaks Kruskal重构树
  6. C++11中的原子操作(atomic operation)
  7. keil5编译时出现 MDK-Pro middleware is not allowed with this license
  8. python 字典 get 小例子
  9. 每天一道算法题(4)——O(1)时间内删除链表节点
  10. Flask12 数据库连接、创建数据库用户、注册模块