[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很喜欢在课间去小卖部买零食.然而不幸的是,这个学期他又有在一教的课,而一教的小卖部姐姐以冷若冰 ...
随机推荐
- eas之action的创建
protected KDWorkButton btnFileManage; protected ActionFileManage actionFileManage = null; pub ...
- Centos7从3.10升级内核到4.9后无法启动解决办法:mpt[23]sas驱动问题
Centos7升级内核后无法启动解决办法:mpt[23]sas驱动问题 前言 这个问题存在有一段时间了,之前做的centos7的ISO,在进行内核的升级以后就存在这个问题: 系统盘在板载sata口上是 ...
- C#第十六节课
out using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.T ...
- C#第十三节课
冒泡排序 using System;using System.Collections.Generic;using System.Linq;using System.Text;using System. ...
- 【数据结构】4.1图的创建及DFS深度遍历(不完善)
声明:本代码仅供参考,根本就不是正确代码(至少在我看来,有很多BUG和不完美的地方) 图的存储方式选择为邻接表,并且headNode只是来存储一个链表的Node首地址额 总之这个代码写的很垃圾呀很垃圾 ...
- [模板]FFT
郝神并没有令我明白这个. 但是巨神的题解太强了. #include <iostream> #include <complex> #include <cmath> # ...
- 重新学习html和css
当初学习前端的时候,属于快速入门那种,没有好好深入学习html和css.如今,在空闲时间重新拿起基础书学习,都会写到一些新的知识. 1.css实现圆角.渐变功能.使用border-radius以及li ...
- 【1】Django概述
道生一,一生二,二生三,三生万物 无名天地之始,有名万物之母 ——老子 python程序web项目开发,是非常重要的一部分,Python为基础的web项目开发的框架有很多,django无疑是最强大we ...
- 输入输出流String间的转换
来自:http://wuhongyu.iteye.com/blog/806791 1.String to inputStream InputStream is = new ByteArrayInp ...
- mysql 基础教程
创建数据库: CREATE DATABASE --DATABASE 或者 SCHEMA数据库集合 IF NOT EXISTS db_name CHARACTER SET utf8 COLLATE ut ...