[hihocoder][Offer收割]编程练习赛57
1-偏差排列
斐波那契数列
#pragma comment(linker, "/STACK:102400000,102400000")
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<vector>
#include<algorithm>
#include<iostream>
#include<map>
#include<queue>
#include<stack>
#include<string>
#include<functional>
#include<math.h>
//#include<bits/stdc++.h>
using namespace std;
typedef long long lint;
typedef vector<int> VI;
typedef pair<int, int> PII;
typedef queue<int> QI; void makedata() {
freopen("input.txt", "w", stdout);
fclose(stdout);
} lint f[]; int main() {
#ifndef ONLINE_JUDGE
freopen("input.txt", "r", stdin);
#endif
//makedata();
std::ios::sync_with_stdio(), cin.tie();
int n;
cin >> n;
f[] = , f[] = ;
for (int i = ; i <= n; i++) f[i] = f[i - ] + f[i - ];
cout << f[n] << endl;
return ;
}
递增N元组
先把每一行排序
dp[i][j]表示从第i行开始,且第i行选择第j个及以后的数字的方案数
#pragma comment(linker, "/STACK:102400000,102400000")
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<vector>
#include<algorithm>
#include<iostream>
#include<map>
#include<queue>
#include<stack>
#include<string>
#include<functional>
#include<math.h>
//#include<bits/stdc++.h>
using namespace std;
typedef long long lint;
typedef vector<int> VI;
typedef pair<int, int> PII;
typedef queue<int> QI;
typedef map<int, int> MII; void makedata() {
freopen("input.txt", "w", stdout);
fclose(stdout);
} int mp[][];
lint dp[][]; int main() {
#ifndef ONLINE_JUDGE
freopen("input.txt", "r", stdin);
#endif
//makedata();
std::ios::sync_with_stdio(), cin.tie();
int n, m, x;
cin >> n >> m;
for (int i = ; i <= n; i++) {
for (int j = ; j < m; j++) {
cin >> mp[i][j];
}
sort(mp[i], mp[i] + m);
}
for (int i = ; i < m; i++) dp[n][i] = m - i;
for (int i = n - ; i >= ; i--) {
int p = m - ;
for (int j = m - ; j >= ; j--) {
dp[i][j] = dp[i][j + ];
while (mp[i + ][p - ] > mp[i][j] && p) p--;
if (mp[i][j] >= mp[i + ][p]) continue;
dp[i][j] += dp[i + ][p];
dp[i][j] %= ;
}
}
cout << dp[][] << endl;
return ;
}
逃离迷宫5
bfs...
#pragma comment(linker, "/STACK:102400000,102400000")
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<vector>
#include<algorithm>
#include<iostream>
#include<map>
#include<queue>
#include<stack>
#include<string>
#include<functional>
#include<math.h>
//#include<bits/stdc++.h>
using namespace std;
typedef long long lint;
typedef vector<int> VI;
typedef pair<int, int> PII;
typedef queue<int> QI;
typedef map<int, int> MII; void makedata() {
freopen("input.txt", "w", stdout);
fclose(stdout);
} struct node {
int x, y, k;
node(int xx, int yy, int kk) : x(xx), y(yy), k(kk) {}
};
queue<node> q;
int d[][][];
string mp[];
const int dx[] = { -, , , };
const int dy[] = { , , , - }; int main() {
#ifndef ONLINE_JUDGE
freopen("input.txt", "r", stdin);
#endif
//makedata();
std::ios::sync_with_stdio(), cin.tie();
int n;
cin >> n;
for (int i = ; i < n; i++) cin >> mp[i];
memset(d, 0x3F, sizeof(d));
while (!q.empty()) q.pop();
if (mp[][] == '.') d[][][] = , q.push(node(, , ));
else d[][][] = , q.push(node(, , ));
while (!q.empty()) {
node p = q.front();
q.pop();
for (int i = ; i < ; i++) {
int px = p.x + dx[i], py = p.y + dy[i];
if (px < || px >= n || py < || py >= n) continue;
if (mp[px][py] == '.') {
if (d[px][py][p.k] > d[p.x][p.y][p.k] + ) {
d[px][py][p.k] = d[p.x][p.y][p.k] + ;
q.push(node(px, py, p.k));
}
} else {
if (p.k == ) {
if (d[px][py][] > d[p.x][p.y][] + ) {
d[px][py][] = d[p.x][p.y][] + ;
q.push(node(px, py, ));
}
}
}
}
}
if (d[n - ][n - ][] != 0x3F3F3F3F || d[n - ][n - ][] != 0x3F3F3F3F) cout << min(d[n - ][n - ][], d[n - ][n - ][]) << endl;
else cout << - << endl;
return ;
}
最大割集
算出每个点相关的边的异或和,割<S,T>中边的异或和就是S集合中点的边异或和的异或和,因为点集内部的边在这些异或和中被计算了两次变成0,只剩下S到T的边。然后按w排序从大到小添加线性基、
#pragma comment(linker, "/STACK:102400000,102400000")
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<vector>
#include<algorithm>
#include<iostream>
#include<map>
#include<queue>
#include<stack>
#include<string>
#include<functional>
#include<math.h>
#include<iomanip>
//#include<bits/stdc++.h>
using namespace std;
typedef long long lint;
typedef vector<int> VI;
typedef pair<int, int> PII;
typedef queue<int> QI;
typedef map<int, int> MII; void makedata() {
freopen("input.txt", "w", stdout);
fclose(stdout);
} template <typename T> class LnBase {
public:
int sz, szc;
T *x;
int *y;
LnBase() {
x = , sz = sizeof(T) << ;
szc = -, resize(sz);
}
void resize(int size) {
sz = size;
if (!x) delete (x);
x = new T[sz + ];
y = new int[sz + ];
memset(x, , sz * sizeof(T));
memset(y, , sz << );
}
T operator[](int h) {
return x[h];
}
//增加一个向量,若该向量能被已有向量线性表示,返回-1;否则返回该向量增加的是哪一个维度
int add(T v) {
for (int i = sz - ; i >= ; i--)
if (v & (T) << i) {
if (!x[i]) {
x[i] = v;
szc = -;
return i;
}
v ^= x[i];
}
return -;
}
//若该向量能被已有向量线性表示,返回1;否则返回0
int find(T v) {
for (int i = sz - ; i >= ; i--) {
if (v & (T) << i && x[i]) v ^= x[i];
if (!v) return ;
}
return ;
}
//线性基能表示出的最大向量
T max() {
T s = ;
for (int i = sz - ; i >= ; i--) {
if ((s ^ x[i]) > s) s ^= x[i];
}
return s;
}
//线性基能表示出的最小向量,为空返回-1
T min() {
for (int i = ; i < sz; i++) if (x[i]) return x[i];
return -;
}
//矩阵标准化
void canonicity() {
int i, j;
for (i = sz - ; i > ; i--)
for (j = i - ; j >= ; j--) if (x[i] & (T) << j) x[i] ^= x[j];
for (szc = i = ; i < sz; i++) if (x[i]) y[szc++] = i;
}
//线性基能表示出的第k大的向量
T kth(long long K) {
if (szc < ) canonicity();
if (K >= 1ll << szc) return -;
T s = ;
for (int i = szc - ; i >= ; i--) if (K & 1ll << i) s ^= x[y[i]];
return s;
}
};
LnBase<lint> lb;
pair<lint, lint> p[]; int main() {
#ifndef ONLINE_JUDGE
freopen("input.txt", "r", stdin);
#endif
//makedata();
std::ios::sync_with_stdio(), cin.tie();
int n, m, u, v;
lint t;
long double sum = ;
cin >> n >> m;
memset(p, , sizeof(p));
for (int i = ; i < n; i++) {
cin >> p[i].first;
sum += p[i].first;
}
for (int i = ; i < m; i++) {
cin >> u >> v >> t;
u--, v--;
p[u].second ^= t, p[v].second ^= t;
}
sort(p, p + n);
long double sel = ;
for (int i = n - ; i >= ; i--) {
if (lb.add(p[i].second) != -) sel += p[i].first;
}
cout << setprecision() << fixed;
cout << ( * sel - sum) << endl;
return ;
}
[hihocoder][Offer收割]编程练习赛57的更多相关文章
- 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中的元素, ...
- ACM学习历程—Hihocoder [Offer收割]编程练习赛1
比赛链接:http://hihocoder.com/contest/hihointerview3/problem/1 大概有一个月没怎么打算法了.这一场的前一场BC,也打的不是很好.本来Div1的A和 ...
- hihocoder offer收割编程练习赛8 C 数组分拆
思路:(引自bfsoyc的回答:http://hihocoder.com/discuss/question/4160) 动态规划.状态dp[i]表示 前i个数的合法的方案数,转移是 dp[i] = s ...
- hihocoder [Offer收割]编程练习赛18 C 最美和弦(dp)
题目链接:http://hihocoder.com/problemset/problem/1532 题解:一道基础的dp,设dp[i][j][k][l]表示处理到第几个数,当前是哪个和弦错了几次初始x ...
- hihoCoder [Offer收割]编程练习赛3 D子矩阵求和
子矩阵求和 http://hihocoder.com/discuss/question/3005 声明一下: n是和x一起的,m是和y一起的 x是横着的,y是纵着的,x往右为正,y往下为正 (非常反常 ...
- hihocoder [Offer收割]编程练习赛52 D 部门聚会
看了题目的讨论才会做的 首先一点,算每条边(u, v)对于n*(n+1)/2种[l, r]组合的贡献 正着算不如反着算 哪些[l, r]的组合没有包含这条边(u, v)呢 这个很好算 只需要统计u这半 ...
- hihocoder [Offer收割]编程练习赛14
A.小Hi和小Ho的礼物 谜之第1题,明明是第1题AC率比C还要低.题目是求在n个不同重量袋子选4袋,2袋给A,2袋给B,使2人获得重量相同,求问方案数. 我也是一脸懵b...o(n2)暴力枚举发现把 ...
- hihocoder [Offer收割]编程练习赛8
第一次做这种比赛,被自己坑的好惨... A.这道题的关键其实是如果有k和n满足kD+F>nL>kD则不能走无限远,分支看似难整理,其实比较简单,F>L根本就不用算了,明摆着就是Bsi ...
随机推荐
- windows开启3306端口并用可视化工具访问远程mysql(授权访问)
开启 MySQL 的远程登陆帐号有两大步: 1.确定服务器上的防火墙没有阻止 3306 端口. MySQL 默认的端口是 3306 ,需要确定防火墙没有阻止 3306 端口,否则远程是无法通过 330 ...
- 武大OJ 706.Farm
Farmer John has a farm. Betsy, a famous cow, loves running in farmer John's land. The noise she made ...
- Tomcat配置文件server.xml(转)
前言 Tomcat隶属于Apache基金会,是开源的轻量级Web应用服务器,使用非常广泛.server.xml是Tomcat中最重要的配置文件,server.xml的每一个元素都对应了Tomcat中的 ...
- 网络请求之GET、POST请求
网络请求-GET请求: 1,NSURL: 请求地址. 2,NSURLRequest :一个NSURLRequest对象就代表一个请求.它包括的信息有: 1)一个NSURL对象 GET请求,不须要写请求 ...
- Codeforces Round #311 (Div. 2)A Ilya and Diplomas
[比赛链接]click here~~ [题目大意] n个人,获取一到三等文凭,每门文凭有大小范围.求最后文凭各颁发多少 [解题思路]直接枚举了, 看完题,赶紧写了一发代码,发现竟然错过注冊时间.系统提 ...
- BestCoder Round #60/HDU 5505 暴力数学
GT and numbers 问题描述 给出两个数NN和MM. NN每次可以乘上一个自己的因数变成新的NN. 求最初的NN到MM至少需要几步. 如果永远也到不了输出-1−1. 输入描述 第一行读入一个 ...
- 频繁模式挖掘 Apriori算法 FP-tree
啤酒 尿布 组合营销 X=>Y,其中x属于项集I,Y属于项集I,且X.Y的交集等于空集. 2类算法 Apriori算法 不断地构造候选集.筛选候选集来挖掘出频繁项集,需要多次扫描原始数据.磁盘I ...
- 在IIS上搭建WebSocket服务器(二)
服务器端代码编写 1.新建一个ASP.net Web MVC5项目 2.新建一个“一般处理程序” 3.Handler1.ashx代码如下: using System; using System.Col ...
- balsamiq mockups 注册
Name: helloWorld Key: eJzzzU/OLi0odswsqslIzcnJD88vykmpsUQCNc41hjV+7q5+AF74Ds8=
- Luogu4198 楼房重建
https://zybuluo.com/ysner/note/1124880 题面 带修改的区间维护最大斜率. 题面 解析 用线段树区间维护斜率. 考虑如何向上合并. 左半段一定有贡献. 如果左半段的 ...