[Offer收割]编程练习赛36
逃离单身节
#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的更多相关文章
- hihocoder [Offer收割]编程练习赛4
描述 最近天气炎热,小Ho天天宅在家里叫外卖.他常吃的一家餐馆一共有N道菜品,价格分别是A1, A2, ... AN元.并且如果消费总计满X元,还能享受优惠.小Ho是一个不薅羊毛不舒服斯基的人,他希望 ...
- hihocoder [Offer收割]编程练习赛61
[Offer收割]编程练习赛61 A:最小排列 给定一个长度为m的序列b[1..m],再给定一个n,求一个字典序最小的1~n的排列A,使得b是A的子序列. 贪心即可,b是A的子序列,把不在b中的元素, ...
- [Offer收割]编程练习赛46
[Offer收割]编程练习赛46赛后题解 A.AEIOU 分析
- ACM学习历程—Hihocoder [Offer收割]编程练习赛1
比赛链接:http://hihocoder.com/contest/hihointerview3/problem/1 大概有一个月没怎么打算法了.这一场的前一场BC,也打的不是很好.本来Div1的A和 ...
- HihoCoder1670 : 比赛日程安排([Offer收割]编程练习赛41)(模拟)
描述 H国编程联赛中有N只队伍,编号1~N. 他们计划在2018年一共进行M场一(队)对一(队)的比赛. 为了让参赛队员能得到充分的休息,联赛组委会决定:每支队伍连续两场比赛之间至少间隔一天.也就是如 ...
- [Offer收割]编程练习赛48
题目1 : 折线中点 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 给定平面上N个点P1, P2, ... PN,将他们按顺序连起来,形成一条折线. 请你求出这条折线的 ...
- [Offer收割]编程练习赛3 - 题目3 : 智力竞赛
智力竞赛 Problem's Link ---------------------------------------------------------------------------- Mea ...
- [Offer收割]编程练习赛5-1 小Ho的防护盾
#1357 : 小Ho的防护盾 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho的虚拟城市正在遭受小Hi的攻击,小Hi用来攻击小Ho城市的武器是一艘歼星舰,这艘歼星 ...
- hiho #1272 买零食 [Offer收割]编程练习赛2
#1272 : 买零食 时间限制:5000ms 单点时限:1000ms 内存限制:256MB 描述 小Ho很喜欢在课间去小卖部买零食.然而不幸的是,这个学期他又有在一教的课,而一教的小卖部姐姐以冷若冰 ...
随机推荐
- HDU_1729_sg函数(dfs)
Stone Game Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Total ...
- 利用Putty/Plink通过ssh tunnel端口转发实现FireFox和Chrome的加密代理访问
如果需要使用远端服务器的DNS:在Firefox中about:config设置 network.proxy.socks_remote_dns ==> true 参考原文:http://think ...
- shell脚本—基础知识,变量
shell脚本本质: 编译型语言 解释型语言 shell编程基本过程 1.建立shell文件 2.赋予shell文件执行权限,使用chmod命令修改权限 3.执行shell文件 shell变量: sh ...
- 【转载】Intellij IDEA的Hibernate简单应用
转载自: https://www.cnblogs.com/yangyquin/p/5438248.html 1.创建数据库及其表 create database demo; use demo ...
- 15.5.6 【Task实现细节】跟踪栈
谈到栈帧(stack frame)时,可能会想到在方法中声明的局部变量.当然,可能还会注意到 一些隐藏的局部变量,如 foreach 循环中的迭代器.但栈上的内容不止这些,至少逻辑上是这样 . 很多 ...
- C# 常用语句
var list = dt.AsEnumerable().Select(t => t.Field<string>("Bed")).ToList();Select( ...
- SQL第二节课
SQL练习题 一. 设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的 ...
- Monkey日志中如何找错误
无响应问题可以在日志中搜索 “ANR” ,崩溃问题搜索 “CRASH” ,内存泄露问题搜索"GC"(需进一步分析),异常问题搜索 “Exception” monkey执行时未 ...
- malloc实现机制、缓冲机制、文件操作、mmap虚拟地址(day06)
一.malloc的实现机制(缓冲机制) 库函数跟系统调用之间的关系 什么是缓冲? 内存分配的原理. 封装 函数A的实现代码中调用了函数B.函数B的功能是函数A主要的功能,这样就说函数A封装了函数B. ...
- svn版本库更新后自动同步到www
注意:www目录一定要用SVN服务器 checkout出Repositories的代码 步骤: (1)新建www根目录 mkdir -p /data/www/lehuo (2)在www根目录下检出(c ...