2017年 湘潭邀请赛(湖南)or 江苏省赛
这套题是叉姐出的,好难啊,先扫一遍好像没有会做的题了,仔细一想好像D最容易哎
Super Resolution |
||
| Accepted : 112 | Submit : 178 | |
| Time Limit : 1000 MS | Memory Limit : 65536 KB | |
Super ResolutionBobo has an n×m picture consists of black and white pixels. He loves the picture so he would like to scale it a×b times. That is, to replace each pixel with a×b block of pixels with the same color (see the example for clarity). InputThe input contains zero or more test cases and is terminated by end-of-file. For each test case, The first line contains four integers n,m,a,b. The i-th of the following n lines contains a binary string of length m which denotes the i-th row of the original picture. Character "
OutputFor each case, output n×a rows and m×b columns which denote the result. Sample Input2 2 1 1 Sample Output10 |
水题直接开搞,就是我把图像放大m*n倍,那不就是周围都是它的重复了,循环搞下。
#include<stdio.h>
int main(){
int n,m,a,b;
while(~scanf("%d%d%d%d",&n,&m,&a,&b)){
getchar();
char s[];
while(n--){
gets(s);
for(int k=;k<a;k++){
for(int i=;i<m;i++){
for(int j=;j<b;j++)
printf("%c",s[i]);
}
printf("\n");
}}} return ;}
然后我也没有会做的题了,群里讲I是脑洞题,我就直接开搞了
Strange Optimization |
||
| Accepted : 38 | Submit : 209 | |
| Time Limit : 1000 MS | Memory Limit : 65536 KB | |
Strange OptimizationBobo is facing a strange optimization problem. Given n,m, he is going to find a real number α such that f(12+α) is maximized, where f(t)=mini,j∈Z|i/n−j/m+t|. Help him! Note: It can be proved that the result is always rational. InputThe input contains zero or more test cases and is terminated by end-of-file. Each test case contains two integers n,m.
OutputFor each case, output a fraction p/q which denotes the result. Sample Input1 1 Sample Output1/2 NoteFor the first sample, α=0 maximizes the function. |
这个题我好像不会哎,这个脑洞开的,1/(m*n*2),这是我第一次猜的,错了啊,接下来我的方向就是找i/n-j/m的最小区间了,毕竟后面的数是个实数,这个答案符合最小公倍数啊,交上去wa,后来才发现是爆int,知道了又发现这个OJ是int64,求心理面积大小
#include <stdio.h>
__int64 gcd(__int64 a,__int64 b)
{
while(b != )
{
__int64 r = b;
b = a % b;
a = r;
}
return a;
}
int main()
{
__int64 m,n;
while(~scanf("%I64d%I64d",&n,&m)){
printf("1/%I64d\n",m/gcd(n,m)*n*);
}
return ;
}
Highway |
||
| Accepted : 37 | Submit : 151 | |
| Time Limit : 4000 MS | Memory Limit : 65536 KB | |
HighwayIn ICPCCamp there were n towns conveniently numbered with 1,2,…,n connected with (n−1) roads. The i-th road connecting towns ai and bi has length ci. It is guaranteed that any two cities reach each other using only roads. Bobo would like to build (n−1) highways so that any two towns reach each using only highways. Building a highway between towns x and y costs him δ(x,y) cents, where δ(x,y) is the length of the shortest path between towns x and y using roads. As Bobo is rich, he would like to find the most expensive way to build the (n−1) highways. InputThe input contains zero or more test cases and is terminated by end-of-file. For each test case: The first line contains an integer n. The i-th of the following (n−1) lines contains three integers ai, bi and ci.
OutputFor each test case, output an integer which denotes the result. Sample Input5 Sample Output19 |
这个题似曾相识,先DFS两次求最长路,树的直径,和蓝桥杯大臣的旅费差不多,然后再其他点到这两个点最长的距离得和。我是做不出来
和hdu2916差不多
都是树形dp,那个题的代码
#include <bits/stdc++.h>
using namespace std;
int len;
int head[],dp[],id[],dp2[],id2[];
//dp[i],从i往下倒叶子的最大距离
//id,最大距离对应的序号
//dp2,次大距离
//id2,次大序号
struct node {
int now,next,len;
} tree[];
void add(int x,int y,int z) { //建树
tree[len].now = y;
tree[len].len = z;
tree[len].next = head[x];
head[x] = len++;
tree[len].now = x;
tree[len].len = z;
tree[len].next = head[y];
head[y] = len++;
}
void dfs1(int root,int p) {
//从节点root往下倒叶子节点的最大距离
//p是root父节点
int i,j,k,tem;
dp[root] = ;
dp2[root] = ;
for(i = head[root]; i!=-; i = tree[i].next) {
k = tree[i].now;
if(k == p)//不能再找父节点
continue;
dfs1(k,root);
if(dp2[root]<dp[k]+tree[i].len) { //比次大的要大
dp2[root] = dp[k]+tree[i].len;
id2[root] = k;
if(dp2[root]>dp[root]) { //次大大于最大,交换其值与id
swap(dp2[root],dp[root]);
swap(id2[root],id[root]);
}
}
}
}
//len为p到root的长度
void dfs2(int root,int p) {
//从父亲节点开始更新
int i,j,k;
for(i = head[root]; i!=-; i = tree[i].next) {
k = tree[i].now;
if(k == p)
continue;
if(k == id[root]) { //最大距离的序号,对应的是dp[k],多以这里要加次大的
if(tree[i].len+dp2[root]>dp2[k]) {
dp2[k] = tree[i].len+dp2[root];
id2[k] = root;
if(dp2[k]>dp[k]) {
swap(dp2[k],dp[k]);
swap(id2[k],id[k]);
}
}
} else {
if(tree[i].len+dp[root]>dp2[k]) {
dp2[k] = tree[i].len+dp[root];
id2[k] = root;
if(dp2[k]>dp[k]) {
swap(dp2[k],dp[k]);
swap(id2[k],id[k]);
}
}
}
dfs2(k,root);
}
}
int main() {
int n,i,j,x,y;
while(~scanf("%d",&n)) {
len = ;
memset(head,-,sizeof(head));
for(i = ; i<=n; i++) {
scanf("%d%d",&x,&y);
add(i,x,y);
}
dfs1(,-);
dfs2(,-);
for(i = ; i<=n; i++)
printf("%d\n",dp[i]);
} return ;
}
2017年 湘潭邀请赛(湖南)or 江苏省赛的更多相关文章
- XTU 1264 - Partial Sum - [2017湘潭邀请赛E题(江苏省赛)]
2017江苏省赛的E题,当时在场上看错了题目没做出来,现在补一下…… 题目链接:http://202.197.224.59/OnlineJudge2/index.php/Problem/read/id ...
- XTU 1267 - Highway - [树的直径][2017湘潭邀请赛H题(江苏省赛)]
这道题可能有毒……总之一会儿能过一会儿不能过的,搞的我很心烦…… 依然是上次2017江苏省赛的题目,之前期末考试结束了之后有想补一下这道题,当时比较懵逼不知道怎么做……看了题解也不是很懂……就只好放弃 ...
- XTU 1260 - Determinant - [2017湘潭邀请赛A题(江苏省赛)][高斯消元法][快速幂和逆元]
是2017江苏省赛的第一题,当时在场上没做出来(废话,那个时候又不懂高斯消元怎么写……而且数论也学得一塌糊涂,现在回来补了) 省赛结束之后,题解pdf就出来了,一看题解,嗯……加一行再求逆矩阵从而得到 ...
- XTU 1261 - Roads - [最小割][2017湘潭邀请赛B题(江苏省赛)]
之前在网上搜了一个下午没搜到这道题的题解,然后同时又对着叉姐写的两行字题解看了一个下午: 虽然基本上已经知道了这题的思路,但愣是因为自己代码实现起来太繁复,外加不确定正确性,没敢码…… 但是一道题肝了 ...
- 2017 CCPC 湘潭邀请赛
都tm快一年了我还没补这套题……再不补怕是要留给退役后乐 Problem A 把$n * (n + 1)$的矩阵补成$(n + 1) * (n + 1)$的,然后高斯消元. Problem B 一看题 ...
- 湘潭邀请赛+蓝桥国赛总结暨ACM退役总结
湘潭邀请赛已经过去三个星期,蓝桥也在上个星期结束,今天也是时候写一下总结了,这应该也是我的退役总结了~ --------------------------------湘潭邀请赛----------- ...
- 1250 Super Fast Fourier Transform(湘潭邀请赛 暴力 思维)
湘潭邀请赛的一题,名字叫"超级FFT"最终暴力就行,还是思维不够灵活,要吸取教训. 由于每组数据总量只有1e5这个级别,和不超过1e6,故先预处理再暴力即可. #include&l ...
- 湘潭邀请赛 Hamiltonian Path
湘潭邀请赛的C题,哈密顿路径,边为有向且给定的所有边起点小于终点,怎么感觉是脑筋急转弯? 以后一定要牢记思维活跃一点,把复杂的事情尽量简单化而不是简单的事情复杂化. #include<cstdi ...
- 2017 湘潭邀请赛&JSCPC G&J
训练的时候对G想了一个假算法..也有很大可能是写错了.. 下来一看别人的G 看起来很奇妙.. 开始把所有的左括号翻成右括号,然后cost*=-1 这样在优先队列中就是最优的 然后for每一段 如果前缀 ...
随机推荐
- Java GUI设置图标
ImageIcon是Icon接口的一个实现类. ImageIcon类的构造函数: ImageIcon() ImageIcon(String filename) //本地图片文件 ImageIcon ...
- intelliJ idea 下载安装
Intellij IDEA是公认的java开发最好的工具,必须学会. 1. 打开网址 https://www.jetbrains.com/ 2. 点击 Intellij IDEA 图标连接,如下图 3 ...
- Java编程基础-运算符
Java中的运算符大致分为:算术运算符.赋值运算符.关系运算符.逻辑运算符和位运算符五类. (1).算术运算符:+ - * / % ++ -- (2).赋值运算符:= += -= * ...
- CF1059B Forgery
思路: 若某个位置是‘.’,说明不能在周围的8个位置下笔.在所有可以下笔的位置填充一次,看能否“包含”需要的图案即可. 实现: #include <iostream> using name ...
- spring boot & mybatis集合的坑
因为是使用的mybatis逆向工程自动生成的实体类和dao层,然后在读取某一个表的content字段时出现问题. 问题描述:在mysql数据库里可以直接查询到这个字段的内容,但是使用java相关的方法 ...
- red5 重新分配 ip
root@hett-OptiPlex-7040:~# ll /usr/local/src/red5/conf/total 144drwxr-xr-x 2 root root 4096 1月 9 ...
- dfs染色法判定二分图
#include<iostream> #include<cstring> using namespace std; ][],color[],n; int dfs(int x,i ...
- 解决Genymotion2.8.1在拖动安装APK文件出现ARMtranslate错误
转载文章:http://blog.csdn.net/solo_talk/article/details/68488129 在新版本的genymotion中,我们拖动安装APK文件的时候会出现一个问题, ...
- 引入了junit为什么还是用不了@Test注解
pom文件明明引入了unit,为什么还是用不了@Test? 配置如下: <dependency> <groupId>junit</groupId> <arti ...
- 第三届上海市大学生网络安全大赛wp&学习
wp 0x00 p200 先分析了程序关键的数据结构 分析程序逻辑,在free堆块的时候没有清空指针,造成悬挂指针,并且程序中给了system('/bin/sh'),可以利用uaf 脚本如下: 1.先 ...