逃离单身节

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<vector>
#include<algorithm>
using std::vector;
using std::sort;
int cmp(const void * x, const void * y) {
//x < y
return (*((double *)(x))) > (*((double *)(y))) ? : -;
}
#define pk putchar(' ')
#define p_ putchar('_')
#define pl putchar('\n');
int main() {
#ifndef ONLINE_JUDGE
freopen("input.txt", "r", stdin);
#endif
int n;
scanf("%d", &n);
for (int i = ; i < n; i++) pk;
for (int i = ; i < n; i++) p_;
for (int i = ; i < * n; i++) pk;
for (int i = ; i < n; i++) p_;
pl;
for (int i = ; i < n - ; i++) {
for (int j = ; j < n - - i; j++) pk;
putchar('/');
for (int j = ; j < n + i + i; j++) pk;
putchar('\\');
for (int j = ; j < n + n - - i + n - - i; j++) pk;
putchar('/');
for (int j = ; j < n + i + i; j++) pk;
putchar('\\');
pl;
}
putchar('/');
for (int j = ; j < * n - ; j++) pk;
putchar('\\');
for (int j = ; j < n; j++) p_;
putchar('/');
for (int j = ; j < * n - ; j++) pk;
putchar('\\');
pl;
for (int i = ; i < n; i++) {
putchar('|');
for (int j = ; j < * n - ; j++) pk;
putchar('|');
pl;
}
for (int i = ; i < * n; i++) {
for (int j = ; j < i; j++) pk;
putchar('\\');
if (i == * n - ) for (int j = ; j < n; j++) p_;
else for (int j = ; j < * n - - * i; j++) pk;
putchar('/');
pl;
}
return ;
}

小Hi的天平

在并查集和二分图之间纠结了好久,直到看了别人的代码才想明白。一开始想的并查集是如果两件物品重量相等就合并两个集合,但这样一来面对一条不等关系的信息就毫无作为了。其实相等和不等表达的信息是等价的,都可以由第一个的种类推出第二个。这样一来,在同一个集合中的物品就之间的关系就不是“属于同一种物品”,而是“他们之间有逻辑关系”,只要确定一个集合中的任意一个是属于A还是B就能确定集合中所有的物品的种类。所以,读入一条xuv后,如果uv属于同一个集合,只需核实其关系是否正确即可;若不属于同一个集合,就合并两个集合。这题的关键代码是写在并查集的路径压缩上,一开始隐隐约约有感觉,但是太菜了,没想到。

c[x]表示x节点与其所在集合根节点是否相同

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<vector>
#include<algorithm>
using std::vector;
using std::sort;
int cmp(const void * x, const void * y) {
//x < y
return (*((double *)(x))) > (*((double *)(y))) ? : -;
}
class Union_Find_Set {
#define MAX_UNION_FIND_SET_SIZE 100000
public:
int setSize;
int father[MAX_UNION_FIND_SET_SIZE];
int c[MAX_UNION_FIND_SET_SIZE];
Union_Find_Set() {
setSize = ;
}
Union_Find_Set(int x) {
setSize = x;
clear();
}
void clear() {
for (int i = ; i < setSize; i++) {
father[i] = i;
}
memset(c, , sizeof(c));
}
int getFather(int x) {
if (x == father[x]) return x;
int y = father[x];
father[x] = getFather(father[x]);
c[x] = c[x] ^ c[y];
return father[x];
}
bool merge(int x, int a, int b) {
int fa = getFather(a), fb = getFather(b);
if (fa != fb) {
father[fa] = fb;
c[fa] = x ^ c[a] ^ c[b];
return true;
} else {
return false;
}
}
int countRoot() {
int ret = ;
for (int i = ; i < setSize; i++) {
if (father[i] = i) {
ret++;
}
}
return ret;
}
};
Union_Find_Set ufs();
int main() {
#ifndef ONLINE_JUDGE
freopen("input.txt", "r", stdin);
#endif
int n, m, t;
bool flag;
scanf("%d", &t);
while (t--) {
flag = true;
scanf("%d%d", &n, &m);
ufs.clear();
for (int i = ; i <= m; i++) {
int x, u, v;
scanf("%d%d%d", &x, &u, &v);
if (!flag) continue;
int fu = ufs.getFather(u), fv = ufs.getFather(v);
if (fu == fv) {
if ((ufs.c[u] ^ ufs.c[v]) != (x)) {
printf("sad\n%d\n", i);
flag = false;
}
} else {
ufs.merge(x, u, v);
}
}
if (flag) printf("great\n");
}
return ;
}

图书馆

剩下30%的数据实在无能为力,绝望。

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<vector>
#include<algorithm>
using namespace std;
int cmp(const void * x, const void * y) {
//x < y
return (*((double *)(x))) > (*((double *)(y))) ? : -;
}
long long a[];
bool f[];
int p[], cnt, c[];
vector<int> q[], qq[];
int main() {
#ifndef ONLINE_JUDGE
freopen("input.txt", "r", stdin);
#endif
memset(f, true, sizeof(f));
f[] = f[] = false;
for (int i = ; i < ; i++)
for (int j = i + i; j < ; j += i)
f[j] = false;
cnt = ;
for (int i = ; i < ; i++) if (f[i]) p[cnt++] = i;
for (int i = ; i <= ; i++) {
q[i].clear();
qq[i].clear();
}
for (int i = ; i <= ; i++) {
int x = i;
for (int j = ; j < cnt; j++) {
if (x == ) break;
int num = ;
while (x % p[j] == ) {
num++;
x /= p[j];
}
if (num > ) {
q[i].push_back(j);
qq[i].push_back(num);
}
}
}
int n, t;
scanf("%d", &t);
while (t--) {
scanf("%d", &n);
for (int i = ; i < n; i++) {
scanf("%lld", &a[i]);
if (a[i] > ) a[i] %= ;
}
if (n > ) {
printf("0\n");
continue;
}
memset(c, , sizeof(c));
int sum = ;
for (int i = ; i < n; i++) sum += (int)a[i];
for (int i = ; i <= sum; i++) {
for (int j = ; j < q[i].size(); j++) {
c[q[i][j]] += qq[i][j];
}
}
for (int i = ; i < n; i++) {
for (int j = ; j <= a[i]; j++) {
for (int k = ; k < q[j].size(); k++) {
c[q[j][k]] -= qq[j][k];
}
}
}
int ans = ;
for (int i = ; i < cnt; i++) {
for (int j = ; j < c[i]; j++) {
ans = (ans * p[i]) % ;
}
}
printf("%d\n", ans);
}
return ;
}

命名的烦恼

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<vector>
#include<algorithm>
#include<iostream>
#include<map>
#include<queue>
#include<string>
using std::vector;
using std::queue;
using std::map;
using std::sort;
using std::string;
#define read(x) scanf("%d", &x)
#define reads(x) scanf("%s", x)
#define write(x) printf("%d ", x)
#define writes(x) printf("%s ", x)
#define writeln(x) printf("%d\n", x)
#define writesln(x) printf("%s\n", x) int cmp(const void * x, const void * y) {
#define datatype int
datatype dx = *((datatype *)(x)), dy = *((datatype *)(y));
//x < y
return dx > dy ? : -;
#undef datatype
} char a[][], str[][];
int cost[][], dp[ << ][];
int main() {
#ifndef ONLINE_JUDGE
freopen("input.txt", "r", stdin);
#endif
int n, m = ;
read(n);
for (int i = ; i < n; i++) reads(a[i]);
for (int i = ; i < n; i++) {
bool flag = false;
for (int j = ; j < n; j++) {
if (i == j) continue;
if (flag) break;
int li = strlen(a[i]), lj = strlen(a[j]);
for (int k = ; k + li - < lj; k++) {
bool find = true;
for (int p = ; p < li; p++) {
if (a[i][p] != a[j][k + p]) {
find = false;
break;
}
}
if (find) {
flag = true;
break;
}
}
}
if (!flag) {
memcpy(str[m], a[i], sizeof(a[i]));
m++;
}
}
for (int i = ; i < m; i++) {
for (int j = ; j < m; j++) {
if (i == j) continue;
int common, li = strlen(str[i]), lj = strlen(str[j]);
for (common = ; common < li && common < lj; common++) {
bool match = true;
for (int k = ; k < common; k++) {
if (str[i][li - common + k] != str[j][k]) {
match = false;
break;
}
}
if (match) cost[i][j] = lj - common;
}
}
}
memset(dp, 0x3F, sizeof(dp));
for (int i = ; i < m; i++) {
dp[ << i][i] = strlen(str[i]);
}
for (int i = ; i < ( << m); i++) {
for (int j = ; j < m; j++) {
if (dp[i][j] == 0x3F3F3F3F) continue;
for (int k = ; k < m; k++) {
if (i & ( << k)) continue;
if (dp[i | ( << k)][k] > dp[i][j] + cost[j][k])
dp[i | ( << k)][k] = dp[i][j] + cost[j][k];
}
}
}
int ans = 0x3FFFFFFF;
for (int i = ; i < m; i++) {
if (dp[( << m) - ][i] < ans) ans = dp[( << m) - ][i];
}
writeln(ans);
return ;
}

[Offer收割]编程练习赛36的更多相关文章

  1. hihocoder [Offer收割]编程练习赛4

    描述 最近天气炎热,小Ho天天宅在家里叫外卖.他常吃的一家餐馆一共有N道菜品,价格分别是A1, A2, ... AN元.并且如果消费总计满X元,还能享受优惠.小Ho是一个不薅羊毛不舒服斯基的人,他希望 ...

  2. hihocoder [Offer收割]编程练习赛61

    [Offer收割]编程练习赛61 A:最小排列 给定一个长度为m的序列b[1..m],再给定一个n,求一个字典序最小的1~n的排列A,使得b是A的子序列. 贪心即可,b是A的子序列,把不在b中的元素, ...

  3. [Offer收割]编程练习赛46

    [Offer收割]编程练习赛46赛后题解 A.AEIOU 分析

  4. ACM学习历程—Hihocoder [Offer收割]编程练习赛1

    比赛链接:http://hihocoder.com/contest/hihointerview3/problem/1 大概有一个月没怎么打算法了.这一场的前一场BC,也打的不是很好.本来Div1的A和 ...

  5. HihoCoder1670 : 比赛日程安排([Offer收割]编程练习赛41)(模拟)

    描述 H国编程联赛中有N只队伍,编号1~N. 他们计划在2018年一共进行M场一(队)对一(队)的比赛. 为了让参赛队员能得到充分的休息,联赛组委会决定:每支队伍连续两场比赛之间至少间隔一天.也就是如 ...

  6. [Offer收割]编程练习赛48

    题目1 : 折线中点 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 给定平面上N个点P1, P2, ... PN,将他们按顺序连起来,形成一条折线. 请你求出这条折线的 ...

  7. [Offer收割]编程练习赛3 - 题目3 : 智力竞赛

    智力竞赛 Problem's Link ---------------------------------------------------------------------------- Mea ...

  8. [Offer收割]编程练习赛5-1 小Ho的防护盾

    #1357 : 小Ho的防护盾 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho的虚拟城市正在遭受小Hi的攻击,小Hi用来攻击小Ho城市的武器是一艘歼星舰,这艘歼星 ...

  9. hiho #1272 买零食 [Offer收割]编程练习赛2

    #1272 : 买零食 时间限制:5000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho很喜欢在课间去小卖部买零食.然而不幸的是,这个学期他又有在一教的课,而一教的小卖部姐姐以冷若冰 ...

随机推荐

  1. Docker 数据卷重复挂载测试

    没想到一年没写博客了,这中间都是记在自己的笔记本上,大部分网上都有,这个好像没有,所以发上来吧! 本文是测试Docker容器(相同目录/父子目录)同时挂载到宿主机(同目录/不同目录)时的情况,废话少说 ...

  2. OSI参考模型(转)

    一.OSI参考模型 自下而上:物理层(物理介质,比特流).数据链路层(网卡.交换机).网络层(IP协议).传输层(TCP/UDP协议).会话层(创建/建立/断开连接).表示层(翻译,编码,压缩,加密) ...

  3. 09.正则表达式re-3.常用的匹配规则

    模式 描述 \w 匹配字母.数字及下划线 \W 匹配不是字母.数字及下划线的字符 \s 匹配任意空白字符,等价于[\t\n\r\f] \S 匹配任意非空字符 \d 匹配任意数字,等价于[0-9] \D ...

  4. Python-Pandas简单操作

    1.直接构建复杂嵌套索引 2. MultiIndex方式构建复杂的索引 多层索引操作 pandas堆叠处理

  5. AtCoder ARC 082E - ConvexScore

    传送门:http://arc082.contest.atcoder.jp/tasks/arc082_c 本题是一个平面几何问题. 在平面直角坐标系中有一个n元点集U={Ai(xi,yi)|1≤i≤n} ...

  6. lucene_07_solr使用IK分词器

    使用IKAnalyzer 中文分析器.. 第一步: 把,IKAnalyzer2012FF_u1j 添加到sol/WEB-INF/lib 目录下. 第二步: 复制IKAnalyzer 的配置文件和自定义 ...

  7. hdu 2586 lca在线算法(朴素算法)

    #include<stdio.h> #include<string.h>//用c/c++会爆栈,用g++ac #define inf 0x3fffffff #define N ...

  8. 很实用的50个CSS代码片段

    原文:50 Useful CSS Snippets Every Designer Should Have          面对每年如此多的 新趋势 ,保持行业的率先是个非常困难问题. 站点设计者和前 ...

  9. Openstack针对nova,cinder,glance使用ceph的虚拟机创建机制优化

     今天在开源中国社区看到有例如以下一个问题: 已经成功把ceph作为cinder和 glance的后端,可是假设作为nova的后端,虚拟机启动速度非常慢,网上查了一下是由于openstack创建虚 ...

  10. JS禁用右键+禁用Ctrl+u+禁用F12

    第一种方法: , , ]; document.oncontextmenu = new Function("event.returnValue=false;"),//禁用右键 doc ...