[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很喜欢在课间去小卖部买零食.然而不幸的是,这个学期他又有在一教的课,而一教的小卖部姐姐以冷若冰 ...
随机推荐
- pyqt5 做的小程序,可以用来UI做个小demo
#!/usr/bin/python3# -*- coding: utf-8 -*- """ZetCode PyQt5 tutorial This program crea ...
- Windows上使用iverilog+gtkwave仿真
主要参考了: https://www.cnblogs.com/lsgxeva/p/8280662.html 谢谢! ------------------------------------------ ...
- iphone 事件冒泡规则
今天碰到的一个比较烦人的问题是,在body上添加事件处理函数,发现在iphone上怎么也没办法触发事件,找了半天,发现iPhone处理冒泡事件的规则: 1.点击某个元素: 2.如果这个元素上没有处理该 ...
- HDU1029 - Ignatius and the Princess IV【水题】
给你n个数字,请你找出出现至少(n+1)/2次的数字. 输入 本题包含多组数据,请处理到EOF: 每组数据包含两行. 第一行一个数字N(1<=N<=999999) ,保证N为奇数. 第二行 ...
- 51Nod - 1134 最长递增子序列【动态规划】
给出长度为N的数组,找出这个数组的最长递增子序列.(递增子序列是指,子序列的元素是递增的) 例如:5 1 6 8 2 4 5 10,最长递增子序列是1 2 4 5 10. Input 第1行:1个数N ...
- vue监听页面大小变化重新刷新布局
在项目中由于某些div元素在布局的时候需要初始化宽高,因为当浏览器缩小屏幕的时候需要重新刷新页面视图. 分析思路: 1.在store中创建state,用于保存当前浏览器的宽.高值. 2.在mounte ...
- 0808关于RDS如何恢复到本地教程
转自http://www.cnblogs.com/ilanni/archive/2016/02/25/5218129.html 公司目前使用的数据库是阿里云的RDS,目前RDS的版本为mysql5.6 ...
- 数据结构----队列:顺序队列&顺序循环队列、链式队列、顺序优先队列
一.队列的概念: 队列(简称作队,Queue)也是一种特殊的线性表,队列的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置插入和删除,而队列只允许在其一端进行插入操作在其 ...
- hdu1716(库函数next_permutation)
题目意思: 现有四张卡片,用这四张卡片能排列出非常多不同的4位数,要求按从小到大的顺序输出这些4位数. 注意首位没有前导0 pid=1716">http://acm.hdu.edu.c ...
- Qt的Socket数据通讯的一个样例。
QTcpServer类 用来侦听port ,获取QTcpSocket. QTcpSocket有 connected的信号(已经连接),还有readyread()信号,表示已经有数据发过来了.准备读取 ...