【组队训练】2016 ACM/ICPC Asia Regional Dalian Online
因为不是一队……毫无晋级的压力……反正有压力也进不去呵呵呵……
开场zr看1006我看1010。。
1010我一直在wa。。。
zr的1006倒是比较轻松的过了。。。然后我让他帮我看10。。。。
跟他讲了半天我代码的逻辑。。。然后我自己看出来的。。。。比赛的代码。。。。写的十分混乱。。。。
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
typedef long long ll;
using namespace std;
const int N = ;
vector<int> G[N]; int a[N], b[N];
int low[N];
int par[N];
int c[N];
int cntv;
ll ans;
int n; int lowbit(int x)
{
return x & (-x);
} int sum(int n) //前n个数的和
{
int ans = ;
while (n > ) {
ans += c[n];
n -= lowbit(n);
}
return ans;
} void add(int pos, int num, int n) //在pos处加num
{
while (pos <= n) {
c[pos] += num;
pos += lowbit(pos);
}
} void dfs(int u) {
//printf("==%d %d %d\n", u, a[u], low[ a[u] ]);
//printf("n = %d\n", n);
int lowu = low[ a[u] ];
int tmp = sum(lowu);
for (unsigned i = ; i < G[u].size(); ++i) {
int v = G[u][i];
dfs(v);
}
int tmp2 = sum(lowu);
add(a[u], , n);
cntv++;
//printf(">>%d %d %d\n", u, tmp, tmp2);
ans += tmp2 - tmp;
} void init() {
memset(c, , sizeof c);
memset(low, , sizeof low);
memset(par, , sizeof par);
} int main()
{
//freopen("in.txt", "r", stdin);
int T;
scanf("%d", &T);
while (T--) {
ll k;
init();
scanf("%d%lld", &n, &k);
//printf("%d %lld\n", n, k);
for (int i = ; i <= n; ++i) {
G[i].clear();
scanf("%d", &a[i]);
b[i] = a[i];
}
sort(b+, b++n);
int cnt = unique(b+, b++n) - (b+);
//printf("cnt=%d\n",cnt);
//for (int i = 1; i <= cnt; ++i) printf("|%d ", b[i]); printf("\n");
int idx = cnt;
for (int i = ; i <= cnt; ++i) {
while ((ll)b[i]*b[idx--] > k) ;
idx++; low[i] = idx;
}//low[i]记录的是i*low[i]<=k的最大值
//for (int i = 1; i <= n; ++i) printf("%d ", low[i]); printf("\n");
for (int i = ; i <= n; ++i) {
a[i] = lower_bound(b+, b++cnt, a[i]) - b;
}
//for (int i = 1; i <= n; ++i) { printf("%d %d\n", a[i], low[ a[i] ]); } int u, v;
for (int i = ; i < n; ++i) {//printf("i=%d\n", i);
scanf("%d%d", &u, &v);
G[u].push_back(v);
par[v] = u;
}
int root = ;
while (par[root]) root = par[root];
//printf("root=%d\n", root);
cntv = ;
ans = ;
dfs(root);
printf("%lld\n", ans);
}
return ;
}
1009总体思路也是我想出来的,但是代码出了一些十分隐蔽的逻辑错误。。。zr比较强大。。。竟然看出来并改对了。。。
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
#include <queue>
typedef long long ll;
using namespace std;
const int N = ;
vector<int> G[N];
int ans[N]; void up(int &x, int y) {
if (x == - || x > y+) x = y+;
} int main()
{//freopen("in.txt", "r", stdin);
int T;
scanf("%d", &T);
while (T--) {
int n, m;
scanf("%d%d", &n, &m);
for (int i = ; i <= n; ++i) G[i].clear();
int u, v;
for (int i = ; i < m; ++i) {
scanf("%d%d", &u, &v);
G[u].push_back(v);
G[v].push_back(u);
}
int s;
scanf("%d", &s);
int cnt = ;
for (int i = ; i <= n; ++i) ans[i] = ; ans[s] = -;
queue<int> q[];
int now = ;
for (unsigned i = ; i < G[s].size(); ++i) {
int v = G[s][i];
ans[v] = -;
q[now].push(v);
cnt++;
}
for (int i = ; i <= *m; ++i) {
if (q[now].empty()) break;
int num = ;
while (q[now].size()) {
int u = q[now].front(); q[now].pop();
//printf("u=%d \n", u);
int tmp = ;
int sz = G[u].size();
for (int j = ; j < sz; ++j) {
int v = G[u][j];
if (ans[v] == -) tmp++;
}
//printf("%d: %d %d %d\n", u, sz, tmp, n);
if (n - sz > cnt - tmp) {
//printf(">>%d %d\n", u, ans[u]);
ans[u] = i+;
num++;
} else {
q[now^].push(u);
} }
cnt -= num;
now ^= ;
} bool ok = true;
for (int i = ; i <= n; ++i) {
if (s == i) continue;
if (ok) ok = false; else printf(" ");
printf("%d", ans[i]);
}
printf("\n");
}
return ;
}
1007坑题。竟然是推公式。。。两个人讨论了下,wa了几次推出来了。。。
#include <cstdio>
#include <cstring>
#include <vector>
#include <algorithm>
#include <iostream>
#include <map>
#include <queue>
#include <stack>
#include <cmath>
typedef long long ll;
#define CLR(x, v) sizeof (x, v, sizeof(x))
using namespace std;
ll n,m;
int main()
{
//freopen("in.txt","r",stdin);
while(cin >> m >> n){
if (m == ) puts("T");
else if ((m/)*(m-m/) > n) puts("F");
else puts("T");
}
return ;
}
02补题吧。。太弱了。。。。
【组队训练】2016 ACM/ICPC Asia Regional Dalian Online的更多相关文章
- 2016 ACM/ICPC Asia Regional Dalian Online 1002/HDU 5869
Different GCD Subarray Query Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65536/65536 K ( ...
- 2016 ACM/ICPC Asia Regional Dalian Online 1006 /HDU 5873
Football Games Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)To ...
- HDU 5874 Friends and Enemies 【构造】 (2016 ACM/ICPC Asia Regional Dalian Online)
Friends and Enemies Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Othe ...
- HDU 5875 Function 【倍增】 (2016 ACM/ICPC Asia Regional Dalian Online)
Function Time Limit: 7000/3500 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- HDU 5873 Football Games 【模拟】 (2016 ACM/ICPC Asia Regional Dalian Online)
Football Games Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)To ...
- HDU 5876 Sparse Graph 【补图最短路 BFS】(2016 ACM/ICPC Asia Regional Dalian Online)
Sparse Graph Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)To ...
- hdu 5868 2016 ACM/ICPC Asia Regional Dalian Online 1001 (burnside引理 polya定理)
Different Circle Permutation Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 262144/262144 K ...
- 2016 ACM/ICPC Asia Regional Dalian Online Football Games
Football Games Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)To ...
- 2016 ACM/ICPC Asia Regional Dalian Online 1008 Function 二分+RMQ
Time Limit: 7000/3500 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total Submissio ...
随机推荐
- 【转】Java自动装箱、拆箱、缓冲池
JDK5以后 Integer a = 3; 这是自动装箱int i = new Integer(2); 这是自动拆箱就是基本类型和其对应的包装类型在需要的时候可以互相 ...
- Java Web开发 之小张老师总结中文乱码解决方案
中文乱码:在以后学习过程中全部采用UTF-8 1.文件的乱码 1.1.项目文本文件默认编码: [右击项目]->[Properties]->[Resource]->[Te ...
- Java泛型:泛型类、泛型接口和泛型方法
根据<Java编程思想 (第4版)>中的描述,泛型出现的动机在于: 有许多原因促成了泛型的出现,而最引人注意的一个原因,就是为了创建容器类. 泛型类 容器类应该算得上最具重用性的类库之一. ...
- 最受欢迎的5个Android ORM框架
在开发Android应用时,保存数据有这么几个方式, 一个是本地保存,一个是放在后台(提供API接口),还有一个是放在开放云服务上(如 SyncAdapter 会是一个不错的选择). 对于第一种方式, ...
- PHP开发搜索引擎技术全解析
谈到网页搜索引擎时,很多人都会想到雅虎.的确,雅虎开创了一个互联网络的搜索时代.然而,雅虎目前用于搜索网页的技术却并非该公司原先自己开发的.2000年8月,雅虎采用了Google这家由斯坦福大学学生创 ...
- C#.Net 如何动态加载与卸载程序集(.dll或者.exe)4-----Net下的AppDomain编程 [摘录]
最近在对AppDomain编程时遇到了一个问题,卸载AppDomain后,在内存中还保留它加载的DLL的数据,所以即使卸载掉AppDomain,还是无法更新它加载的DLL.看来只有关闭整个进程来更新D ...
- poj 2996 Help Me with the Game(模拟)
题目:http://poj.org/problem?id=2996 题意:给出 棋盘 情况 输出 白棋 和 黑棋在 棋盘上的 白棋为大写字母 黑棋为小写字母 棋盘 左下点为原点(1,a) 输出 是 按 ...
- extends:类似于java中的继承特征,extends="struts-default"
extends:类似于java中的继承特征,extends="struts-default"就是继承struts-default.xml,它里面定义了许多跳转类型.拦截器等一些常用 ...
- ORACLE【0】:基本操作
最新工作中用到oracle越来越多,自己虽然也能写点SQL.存储过程.触发器什么的,但是对数据库管理还是陌生的很,现在就将自己最近所学的一步一步整理下来. 1.windows上如何启动oracle 安 ...
- UVa 1151 (枚举 + MST) Buy or Build
题意: 平面上有n个点,现在要把它们全部连通起来.现在有q个套餐,如果购买了第i个套餐,则这个套餐中的点全部连通起来.也可以自己单独地建一条边,费用为两点欧几里得距离的平方.求使所有点连通的最小费用. ...