最短路+拆点 A As long as Binbin loves Sangsang

题意:从1走到n,每次都是LOVE,问到n时路径是连续多个"LOVE"的最短距离.秀恩爱不想吐槽.

分析:在普通的最短路上有寻路的限制,把一个点看成4个点,表示通过某一个字符到该点的最短距离.注意自环的处理,还有距离会爆int。

#include <bits/stdc++.h>

const int N = 1314 + 5;
const int M = 13520 + 5;
const long long INF = 200000000000LL;
struct Edge {
int v, w, ch, nex;
};
Edge edge[M<<1];
int head[N];
int n, m, etot; void init_edge() {
etot = 0;
memset (head, -1, sizeof (head));
} void add_edge(int u, int v, int w, char ch) {
edge[etot].v = v; edge[etot].w = w;
edge[etot].nex = head[u];
if (ch == 'L') {
edge[etot].ch = 0;
} else if (ch == 'O') {
edge[etot].ch = 1;
} else if (ch == 'V') {
edge[etot].ch = 2;
} else if (ch == 'E') {
edge[etot].ch = 3;
}
head[u] = etot++;
} struct Node {
int u, id;
};
long long dis[N][4];
int cnt[N][4];
bool vis[N][4]; void SPFA(int s) {
for (int i=1; i<=n; ++i) {
for (int j=0; j<4; ++j) {
vis[i][j] = false;
dis[i][j] = INF;
cnt[i][j] = 0;
}
}
dis[s][3] = 0; vis[s][3] = true;
std::queue<Node> que;
que.push ((Node) {s, 3});
while (!que.empty ()) {
Node now = que.front (); que.pop ();
int u = now.u, id = now.id;
vis[u][id] = false;
for (int i=head[u]; ~i; i=edge[i].nex) {
Edge &e = edge[i];
if (e.ch != (id + 1) % 4) {
continue;
}
if (dis[e.v][e.ch] > dis[u][id] + e.w || dis[e.v][e.ch] == 0) {
dis[e.v][e.ch] = dis[u][id] + e.w;
cnt[e.v][e.ch] = cnt[u][id];
if (e.ch == 3) {
cnt[e.v][e.ch]++;
}
if (!vis[e.v][e.ch]) {
vis[e.v][e.ch] = true;
que.push ((Node) {e.v, e.ch});
}
} else if ((dis[e.v][e.ch] == dis[u][id] + e.w || dis[e.v][e.ch] == 0) && cnt[e.v][e.ch] <= cnt[u][id]) {
cnt[e.v][e.ch] = cnt[u][id];
if (e.ch == 3) {
cnt[e.v][e.ch]++;
}
if (!vis[e.v][e.ch]) {
vis[e.v][e.ch] = true;
que.push ((Node) {e.v, e.ch});
}
}
}
}
} int main() {
int T;
scanf ("%d", &T);
for (int cas=1; cas<=T; ++cas) {
init_edge ();
scanf ("%d%d", &n, &m);
char ch[2];
for (int i=0; i<m; ++i) {
int u, v, l;
scanf ("%d%d%d%s", &u, &v, &l, ch);
add_edge (u, v, l, ch[0]);
add_edge (v, u, l, ch[0]);
}
SPFA (1);
if (dis[n][3] == INF || cnt[n][3] == 0) {
printf ("Case %d: Binbin you disappoint Sangsang again, damn it!\n", cas);
} else {
printf ("Case %d: Cute Sangsang, Binbin will come with a donkey after travelling %I64d meters and finding %d LOVE strings at last.\n", cas, dis[n][3], cnt[n][3]);
}
}
return 0;
}

DP+优化 C Dragon Ball

题意:m个时间,每个时间去取一个龙珠,代价是距离|x-ball[i].pos|,此时人移动到龙珠的位置,还有该龙珠的代价ball[i].cost,问最小代价。

分析:,另一种情况同理,先对每个时间的位置排序,求i-1时间前缀最小的转移就好了。

#include <bits/stdc++.h>

const int N = 50 + 5;
const int M = 1000 + 5;
const int INF = 0x3f3f3f3f;
struct Ball {
int pos, cost;
bool operator < (const Ball &rhs) const {
return pos < rhs.pos;
}
};
Ball ball[N][M];
int dp[N][M];
int m, n, x; int main() {
int T;
scanf ("%d", &T);
while (T--) {
scanf ("%d%d%d", &m, &n, &x);
for (int i=1; i<=m; ++i) {
for (int j=1; j<=n; ++j) {
scanf ("%d", &ball[i][j].pos);
}
}
for (int i=1; i<=m; ++i) {
for (int j=1; j<=n; ++j) {
scanf ("%d", &ball[i][j].cost);
}
std::sort (ball[i]+1, ball[i]+1+n);
}
memset (dp, INF, sizeof (dp));
for (int i=1; i<=n; ++i) {
dp[1][i] = abs (ball[1][i].pos - x) + ball[1][i].cost;
}
for (int i=2; i<=m; ++i) {
int k = 1, mn = INF;
for (int j=1; j<=n; ++j) {
for (; k<=n && ball[i-1][k].pos <= ball[i][j].pos; ++k) {
mn = std::min (mn, dp[i-1][k] - ball[i-1][k].pos);
}
dp[i][j] = mn + ball[i][j].pos + ball[i][j].cost;
}
k = n; mn = INF;
for (int j=n; j>=1; --j) {
for (; k>=1 && ball[i-1][k].pos > ball[i][j].pos; --k) {
mn = std::min (mn, dp[i-1][k] + ball[i-1][k].pos);
}
dp[i][j] = std::min (dp[i][j], mn - ball[i][j].pos + ball[i][j].cost);
}
}
int ans = INF;
for (int i=1; i<=n; ++i) {
ans = std::min (ans, dp[m][i]);
}
printf ("%d\n", ans);
}
return 0;
}

模拟 E Matrix operation

读懂题,照着模拟

#include <bits/stdc++.h>

int mat[4][4] = {2, 3, 1, 1,
1, 2, 3, 1,
1, 1, 2, 3,
3, 1, 1, 2};
int a[4][4], tmp[4]; void run() {
int ans[4][4];
for (int i=0; i<4; ++i) {
for (int j=0; j<4; ++j) {
for (int k=0; k<4; ++k) {
int t;
if (mat[i][k] == 2) {
t = a[k][j] << 1;
if (t > 0xFF) {
t ^= 0x1B;
}
if (t > 0xFF) {
t %= (0xFF + 1);
}
} else if (mat[i][k] == 3) {
t = a[k][j] << 1;
if (t > 0xFF) {
t ^= 0x1B;
}
t ^= a[k][j];
if (t > 0xFF) {
t %= (0xFF + 1);
}
} else {
t = a[k][j];
}
tmp[k] = t;
}
int t = tmp[0];
for (int i=1; i<4; ++i) {
t ^= tmp[i];
}
ans[i][j] = t;
}
}
for (int i=0; i<4; ++i) {
for (int j=0; j<3; ++j) {
printf ("%02X ", ans[i][j]);
}
printf ("%02X\n", ans[i][3]);
}
} int main() {
int T;
scanf ("%d", &T);
while (T--) {
for (int i=0; i<4; ++i) {
for (int j=0; j<4; ++j) {
scanf ("%X", &a[i][j]);
}
}
run ();
if (T) {
puts ("");
}
}
return 0;
}

数学+快速幂 F Palindrome graph

题意:一个n*n的图填充颜色使得图如何反转或旋转都不会变化。

分析:考虑到是中心对称的,只要考虑1/8的图(三角形)就行了,假设总和x个。填充过的颜色的位置转移到1/8的图中(假设y个),其他的地方能涂k种颜色,答案是k^(x-y)。

#include <bits/stdc++.h>

const int MOD = 100000007;

int pow_mod(int x, int n) {
int ret = 1;
while (n) {
if (n & 1) {
ret = (long long) ret * x % MOD;
}
x = (long long) x * x % MOD;
n >>= 1;
}
return ret;
} const int N = 10005; bool vis[N/2][N/2];
int n, m, k; int main() {
while (scanf ("%d%d%d", &n, &m, &k) == 3) {
memset (vis, false, sizeof (vis));
int mid = n / 2;
if (n & 1) {
mid++;
}
for (int i=0; i<m; ++i) {
int x, y;
scanf ("%d%d", &x, &y);
x++; y++;
if (x > mid) {
x = n + 1 - x;
}
if (y > mid) {
y = n + 1 - y;
}
if (x < y) {
std::swap (x, y);
}
vis[x][y] = true;
}
int c = 0;
for (int i=1; i<=mid; ++i) {
for (int j=1; j<=i; ++j) {
if (!vis[i][j]) {
c++;
}
}
}
printf ("%d\n", pow_mod (k, c));
}
return 0;
}

DFS序+线段树 G Successor

题意:给了n个人的上下级关系,每个人有能力和忠诚度,问如果上级被炒了,下属里能力比他强,忠诚度最高的是谁。

分析:其实就是给了一棵树,DFS序转换为线性序列,每一个上级管辖一段区间,按照能力从大到小排序,每次插入能力比上级强的,相同的也同时插入,询问忠诚度最高的对应人的id即是答案。

#include <bits/stdc++.h>

const int N = 5e4 + 5;
struct Person {
int sup, loy, ab, id;
bool operator < (const Person &rhs) const {
return ab > rhs.ab;
}
}p[N];
int n, m;
int left[N], right[N];
std::map<int, int> ID;
std::vector<int> edge[N];
int tot; #define lson l, mid, o << 1
#define rson mid + 1, r, o << 1 | 1 int mx[(N<<1)<<2];
void push_up(int o) {
mx[o] = std::max (mx[o<<1], mx[o<<1|1]);
} void updata(int p, int v, int l, int r, int o) {
if (l == r) {
mx[o] = v;
return ;
}
int mid = l + r >> 1;
if (p <= mid) {
updata (p, v, lson);
} else {
updata (p, v, rson);
}
push_up (o);
} int query(int ql, int qr, int l, int r, int o) {
if (ql <= l && r <= qr) {
return mx[o];
}
int mid = l + r >> 1, ret = -1;
if (ql <= mid) {
ret = std::max (ret, query (ql, qr, lson));
}
if (qr > mid) {
ret = std::max (ret, query (ql, qr, rson));
}
return ret;
} void DFS(int u) {
left[u] = tot++;
for (auto v: edge[u]) {
DFS (v);
}
right[u] = tot;
} int ans[N]; void solve() {
tot = 1;
DFS (0);
//build (1, tot-1, 1);
memset (mx, -1, sizeof (mx));
std::sort (p+1, p+n);
ans[0] = -1;
for (int j, i=1; i<n; i=j) {
j = i;
while (j < n && p[j].ab == p[i].ab) {
int id = p[j].id;
ans[id] = ID[query (left[id]+1, right[id]-1, 1, tot-1, 1)];
j++;
}
j = i;
while (j < n && p[j].ab == p[i].ab) {
int id = p[j].id;
updata (left[id], p[j].loy, 1, tot-1, 1);
j++;
}
}
} int main() {
int T;
scanf ("%d", &T);
while (T--) {
scanf ("%d%d", &n, &m);
for (int i=0; i<n; ++i) {
edge[i].clear ();
}
ID.clear ();
ID[-1] = -1;
for (int i=1; i<n; ++i) {
scanf ("%d%d%d", &p[i].sup, &p[i].loy, &p[i].ab);
p[i].id = i;
edge[p[i].sup].push_back (i);
ID[p[i].loy] = i;
}
solve ();
for (int i=0; i<m; ++i) {
int j;
scanf ("%d", &j);
printf ("%d\n", ans[j]);
}
}
return 0;
}

2012 Multi-University #7的更多相关文章

  1. 针对于网络安全领域中基于PCAP流量的数据集

    网络安全领域中基于PCAP流量的数据集 MAWI Working Group Traffic Archive URL:http://mawi.wide.ad.jp/mawi/ CIC dataset ...

  2. Parallel NetCDF 简介

    Parallel NetCDF API 所有C接口前加ncmpi前缀,Fortran接口前加nfmpi前缀 函数返回整数 NetCDF 状态变量 1. Variable and Parameter T ...

  3. 视觉中的深度学习方法CVPR 2012 Tutorial Deep Learning Methods for Vision

    Deep Learning Methods for Vision CVPR 2012 Tutorial  9:00am-5:30pm, Sunday June 17th, Ballroom D (Fu ...

  4. Google Interview University - 坚持完成这套学习手册,你就可以去 Google 面试了

    作者:Glowin链接:https://zhuanlan.zhihu.com/p/22881223来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 原文地址:Google ...

  5. SQL Server 2012 内存管理 (memory management) 改进

    SQL Server 2012 的内存管理和以前的版本相比,有以下的一些变化. 一.内存分配器的变化 SQL Server 2012以前的版本,比如SQL Server 2008 R2等, 有sing ...

  6. 西安理工大学 李爱民 Xi'an University of Technology, Aimin Li

    李爱民-西安理工大学计算机科学与工程学院 ● 简介(Introduction)-> 李爱民(Aimin Li),男,湖北随州人,西安电子科学大学博士(PhD),中共党员.中国计算机学会会员,CS ...

  7. 微软BI SSRS 2012 Metro UI Win 8 风格的报表课程案例全展示

    开篇介绍 微软BI SSRS 2012 Metro UI 高端报表视频教程 (http://www.hellobi.com/course/15)课程从2014年6月开始准备,于2014年9月在 天善B ...

  8. Online handwriting recognition using multi convolution neural networks

    w可以考虑从计算机的“机械性.重复性”特征去设计“低效的”算法. https://www.codeproject.com/articles/523074/webcontrols/ Online han ...

  9. Patch multi versions of windows via Power shell

    Patch multi versions of windows via Power shell $version = Get-WmiObject -Class Win32_OperatingSyste ...

  10. Weblogic多数据源(Multi Data Sources)应用实践

    原创 2012年03月29日 10:55:28 标签: weblogic / 数据库 / 负载均衡 / 数据中心 / jdbc / 应用服务器   大型系统在进行数据库部署时,常常会分为主数据应用中心 ...

随机推荐

  1. web前端基础知识-(三)JavaScript基本操作

    JavaScript 是一种轻量级的编程语言. JavaScript 是可插入 HTML 页面的编程代码. JavaScript 插入 HTML 页面后,可由所有的现代浏览器执行. JavaScrip ...

  2. Java创建对象的几种方法

    有时候,也可能碰到这样面试题,如: Java创建对象有哪几种方法? 除了new之外,java创建对象还有哪几种方式? 本文结合例子,给出几种Java创建对象的方法,Here we go~~~~ 使用n ...

  3. 用U盘安装系统的好用的PE系统:通用PE V6.1下载

    用U盘安装系统的好用的PE系统:通用PE V6.1下载 PE是一款用其他介质(我们最常用的是U盘)启动安装电脑系统的简易操作系统,在XP系统中 最经典的是扬州老毛桃出品的只有100多兆的XP内核的PE ...

  4. no module named flask.ext.login

    在用安装了flask-login后使用时发现了问题,查了许多资料尝试了许多办法: 1.以为是文件结构的问题,因为flask-login包中没有__init__.py结果编译后还是不行 2.以为是路径问 ...

  5. Java排序算法——拓扑排序

    package graph; import java.util.LinkedList; import java.util.Queue; import thinkinjava.net.mindview. ...

  6. flask初探

    为什么我们需要模板 让我们来考虑下我们该如何扩充我们这个小的应用程序. 我们希望我们的微博应用程序的主页上有一个欢迎登录用户的标题,这是这种类型的应用程序的一个"标配".忽略本应用 ...

  7. Swift 3.0 【Swift 3.0 相较于 Swift 2.2 的变化】

    一.编译器和语法变化 函数或方法参数 调用函数或方法时从第一个参数开始就必须指定参数名 在Swift的历史版本中出现过在调用函数时不需要指定任何函数参数(或者从第二个参数开始指定参数名),在调用方法时 ...

  8. Coursera系列-R Programming-Final Week-Assignment3 & 总结

    博客总目录,记录学习R与数据分析的一切:http://www.cnblogs.com/weibaar/p/4507801.html  ------- 经过周末一个半天的努力,终于把这次的Assignm ...

  9. gulp使用技巧-删除node_modules文件夹,解决目录层次太深删除报错的问题

    问题描述: 在使用gulp当中,自动生成的node_modules文件夹,因为文件目录层级太深,无法系统删除,用360粉碎工具也报错 解决方法: 使用npm中的插件rimraf,专门用于删除的模块插件 ...

  10. xampp本地配置多域名

    xampp内建apache服务器,也是可以配置vhosts的 1. 打开httpd.conf文件,搜索vhosts 发现这句话: # Virtual hosts Include conf/extra/ ...