indeed 4.22 第一次网测
1.第一题 没有看
2. 由于数据范围很小,所以每一层需要全排列,寻找最小的花费,然后所有层加起来就是最后的结果。
#include<bits/stdc++.h>
#define pb push_back
typedef long long ll;
using namespace std;
typedef pair<int, int> pii;
const int maxn = 1e3 + ;
int n;
int m;
int a[][][];
int p[]; void solve() {
cin >> n >> m;
ll res = ;
for (int j = ; j < n; j++) {
cin >> a[][j][] >> a[][j][];
}
for (int i = ; i <= m; i++) {
for (int j = ; j < n; j++) {
cin >> a[i][j][] >> a[i][j][];
}
if(i == ) continue;
for (int j = ; j < n; j++)
p[j] = j;
ll mr = INT_MAX;
do {
ll t = ;
for (int j = ; j < n; j++) {
t += abs(a[i][p[j] ][] - a[i - ][j][] ) + abs(a[i][p[j] ][] - a[i - ][j][] );
}
mr = min(t, mr);
} while(next_permutation(p, p + n));
res += mr;
}
cout << res << endl; } int main() {
freopen("test.in", "r", stdin);
//freopen("test.out", "w", stdout);
ios::sync_with_stdio();
cin.tie(); cout.tie();
solve();
return ;
}
3.数据范围也是很小,枚举每一条边,然后存在不存在,进行判断累加。边的个数6 * 5 / 2 = 15. 1 << 15 = 32000. 然后乘上判断连通的复杂度,结果也是很小。
判断连通可以用bfs或者dfs, dsu都是可以的。
#include<bits/stdc++.h>
#define pb push_back
typedef long long ll;
using namespace std;
typedef pair<int, int> pii;
const int maxn = 1e3 + ;
int n, m;
//set<pii> se;
int f[];
int a[][];
int b[][];
void init() {
for (int i = ; i <= n; i++) f[i] = i;
}
int fd(int x) {
if(x == f[x]) return x;
return f[x] = fd(f[x]);
}
bool check() {
int sz = n;
for (int i = ; i <= n; i++) {
for (int j = i + ; j <= n; j++) {
if(a[i][j]) {
int t1 = fd(i);
int t2 = fd(j);
if(t1 != t2) {
sz--;
f[t1] = t2;
}
}
}
}
return sz == ;
}
ll res; void work(int x, int y) {
//cout << x << " " << y << endl;
if(x > n) {
init();
res += check();
return;
}
if(y > n) {
work(x + , x + );
return;
}
work(x, y + );
if(b[x][y]) return;
a[x][y] = a[y][x] = ;
work(x, y + );
a[x][y] = a[y][x] = ;
}
void solve() {
cin >> n >> m;
int x, y;
for (int i = ; i < m; i++) {
cin >> x >> y;
//if(x > y) swap(x, y);
//se.insert({x, y});
b[x][y] = b[y][x] = ;
}
work(, );
cout << res << endl;
} int main() {
freopen("test.in", "r", stdin);
//freopen("test.out", "w", stdout);
ios::sync_with_stdio();
cin.tie(); cout.tie();
solve();
return ;
}
4. 第四题稍微花了一些时间。 首先题目求解满足条件的最小, 那就是比这个大的都是可以满足条件的, 满足二分的性质。
然后给定答案,如何快速的判断是否满足要求, 贪心策略进行。由于 n = 1e4, 这个数其实挺小的, 排序, 贪心 可以的。
#include<bits/stdc++.h>
#define pb push_back
typedef long long ll;
using namespace std;
typedef pair<int, int> pii;
const int maxn = 1e4 + ;
int n, a, b;
ll h[maxn];
ll tmp[maxn];
int tot;
bool check(ll x) {
ll ra, rb;
ra = rb = ;
tot = ;
for (int i = ; i < n; i++) {
if(h[i] >= x) {
ll c = h[i] / x;
if(ra + c > a) {
ll t = h[i] - x * (a - ra);
ra = a;
if(t > ) tmp[tot++] = t;
} else {
ra += h[i] / x;
int t = h[i] % x;
if(t > ) tmp[tot++] = t;
} } else {
tmp[tot++] = h[i];
}
//if(ra > a) return 0;
}
sort(tmp, tmp + tot, greater<ll>());
for (int i = ; i < tot; i++) {
if(ra < a) {
ra++;
} else {
rb += tmp[i];
}
}
return ra + rb <= b;
}
void solve() {
cin >> n >> a >> b;
for (int i = ; i < n; i++) {
cin >> h[i];
}
sort(h, h + n, greater<ll>());
ll left = , right = 1e9 + ;
while(left < right) {
ll mid = (left + right) / ;
//cout << mid << " " << left << " " << right << endl;
if(check(mid)) right = mid;
else left = mid + ; }
if(check(left)) cout << left << endl;
else cout << - << endl;
} int main() {
//freopen("test.in", "r", stdin);
//freopen("test.out", "w", stdout);
ios::sync_with_stdio();
cin.tie(); cout.tie();
solve();
return ;
}
indeed 4.22 第一次网测的更多相关文章
- indeed2017校招在线编程题(网测)三
A. Calculate Sequence 分析:就是斐波那契递推公式,但是初始值是指定的,只用求第10个数,数据范围和复杂度都比较小,直接写. B. 忘了叫啥了. 就是有a-j十个字符组成的字符串, ...
- 2014-CVTE网测部分软件技术测试题及答案
1.叉树的先序遍历序列和后序遍历序列正好相反,则该二叉树满足的条件是(D) A.空或只有一个结点 B.高度等于其结点数 C.该二叉树是完全二叉树 D.所有结点无右孩子 应该是二叉树的每个结点都只有一个 ...
- wap网测一道题目
1. 给定一个字符串s, 1 <= len(s) <= 3000, 定义odd palindrome string为长度为奇数的回文串, 求s中该奇回文串的个数. 比如axbcba , 结 ...
- wap 5.23 网测几道题目
1. n个犯人,m个省份, 如果相邻的2个犯人来自同一省份,则是不安全的,求不安全的个数. 正难则反,用全部的个数减去非法的个数,就是最后的答案. m^n - m * (m - 1) ^ (n - 1 ...
- 5.27 indeed 第三次网测
1. 第一题, 没有看 2. 暴力枚举.每一个部分全排列, 然后求出最大的请求数. #include<bits/stdc++.h> #define pb push_back typedef ...
- indeed 5.13 第二次网测
题目描述,我找不见了,大概写一下想法和代码吧. 1. 没有看 2. 由于数据范围很小,就是简单的枚举,求全排列,然后更新答案. #include<bits/stdc++.h> #defin ...
- elasticsearch系列(二) esrally压测
环境准备 linux centOS(工作环境) python3.4及以上 pip3 JDK8 git1.9及以上 gradle2.13级以上 准备过程中的坑 这些环境准备没什么太大问题,都是wget下 ...
- mysql每秒最多能插入多少条数据 ? 死磕性能压测
前段时间搞优化,最后瓶颈发现都在数据库单点上. 问DBA,给我的写入答案是在1W(机械硬盘)左右. 联想起前几天infoQ上一篇文章说他们最好的硬件写入速度在2W后也无法提高(SSD硬盘) 但这东西感 ...
- 使用Holer外网SSH访问内网(局域网)Linux系统
1. Holer工具简介 Holer exposes local servers behind NATs and firewalls to the public internet over secur ...
随机推荐
- Django - orm外键操作
1.orm外键操作 创建外键: 备注:ForeignKey两个参数,1个为关联的表名,1个为关联的字段名: 在django2.0后,定义外键和一对一关系的时候需要加on_delete选项,此参数为了避 ...
- jquery动态生成二维码添加自定义logo
动态生成二维码中间带logo. jquery.qrcode.js 动态生成二维码api很简单. 引入jquer(版本任意),引入jquery.qrcode.js 不需要中间带logo这样就可以了.带l ...
- Ac自动机基础题集合
Ac_automaton的板子打熟以后发现碰到题不会做,而且还是比较纯的板子,只要改几处地方就可以,Ac_automation有许多优秀而fantasy的性质,下面粘几个题,来记录一下做题的心得. 1 ...
- (问题待解决)sql查询不显示前置‘0’的问题
SELECT * , ,),() ) ' end)) from CourseBooksNotes ),)),)+'秒'; ),)),)),)+'秒'
- linux学习4-crontab定时任务
crontab -e 在当前用户下创建定时任务 我们通过这样一张图来了解 crontab 的文档编辑的格式与参数 在了解命令格式之后,我们通过这样的一个例子来完成一个任务的添加,在文档的最后一排加上 ...
- Dubbo学习总结(2)——Dubbo架构详解
一.前言 部门去年年中开始各种改造,第一步是模块服务化,这边初选dubbo试用在一些非重要模块上,慢慢引入到一些稍微重要的功能上,半年时间,学习过程及线上使用遇到的些问题在此总结下. 整理这篇文章差不 ...
- [HZOJ10420]计算
[HZOJ10420]计算 题目 给定一个数列,第i个位置包含两个数ai,bi 每次询问给出x,y 求数列ai*x+bi*y的最大值 输入所有数为自然数,在int范围内 INPUT 第一行为n,m.n ...
- RPC框架分析
RPC框架分析 常用的框架 .net(WCF) .net中分布式框架集大成者,提供多种通信方式,多种安全策略的调用(配置繁琐). java 1.RMI JDK原生(严格的说来算不上框架). 2.Du ...
- html实现 省——市——区三级联动
html实现 省——市——区三级联动 html中实现三级联动是一个不错的demo,博主在这里跟大家分享一下实现的过程,以及自己在过程中出现的一些问题,仅供参考. 首先我们将全国的省市区数据导入进来, ...
- ubuntu设置不睡眠的方法
Ubuntu系统不睡眠设置方法:要完成这个设置Ubuntu有两种方法:第一种是打开 System Settings –> Power,中文版是打开系统设置 -> 电源),然后进行设置.但不 ...