博客的开始,先聊聊代码实现:

每次比赛以后,要有归纳错误的习惯.

错误小结:

1.读入:scanf(“%c”)会读入回车和空格,但cin不会.

2.对于二维数组的输入,不能把m,n搞混了,会引起严重的程序错误,轻则Wrong Answer,重则Run Time Error.

注意DFS的边界问题。

比赛内容及赛后反思

Problem 1

1339. disease(细菌) (Standard IO)

时间限制: 1000 ms  空间限制: 131072 KB  具体限制  

Goto ProblemSet

题目描述

  近期,农场出现了D (1<= D <=15)种细菌。John 要从他的 N (1<= N <=1,000)头奶牛中尽可能多地选些产奶。但是如果选中的奶牛携带了超过 K (1<= K <=D)种不同细菌,所生产的奶就不合格。请你帮助John 计算出最多可以选择多少头奶牛。
 

输入

第一行:三个整数 N, D, K
下面N行:第行表示一头牛所携带的细菌情况。第一个整数 di 表示这头牛所携带的细菌种类数,后面di个整数表示这些细菌的各自种类标号。

输出

只一个数 M,最大可选奶牛数。
 

样例输入

 

样例输出

 
 

数据范围限制

 
 

提示

样例

输入  

6 3 2

0

1 1

1 2

1 3

2 2 1

2 2 1

选择:
1,2,3,5,6
只有1#和2#两种细菌

输出

5

    
 
 
 
 
 
服务器时间: Fri Aug 02 2019 18:22:07 GMT+0800 (中国标准时间)Fortuna OJ 项目
作者: moreDRD; 协力: twilightMcHobby
由 CodeIgniter / Bootstrap 驱动
Glyphicons 提供图标

思路:暴搜。

代码:(TLE错误代码22.2分)

#include <cstdio>
#include <iostream>
#define rr register
using namespace std;
int n,d,k,a[][],ans1=,ans=;
bool c[];
int max(int a,int b)
{
if(a>b)
return a;
return b;
}
void dfs(int i,bool xz,int jun,int sum)
{
bool tmp[],temp=jun;
for(rr int j=;j<=;j++)
tmp[j]=c[j];
if(jun>k)
return;
if(i>n)
{
ans=max(ans,sum);
return;
}
if(xz)
{
for(rr int j=;j<=k;j++)
if(a[i][j] && a[i][j]!=c[j])
{
c[j]=a[i][j];
jun++;
}
if(jun>k)
{
for(rr int j=;j<=;j++)
c[j]=tmp[j];
jun=temp;
}
else
sum++;
}
dfs(i+,true,jun,sum);
dfs(i+,false,jun,sum);
}
int main()
{
int tmp;
scanf("%d %d %d",&n,&d,&k);
for(rr int i=;i<=n;i++)
{
scanf("%d",&a[i][]);
if(a[i][]==)
{
ans1++;
i--;
n--;
}
if(a[i][]>k)
{
i--;
n--;
continue;
}
for(rr int j=;j<=a[i][];j++)
{
scanf("%d",&tmp);
a[i][tmp]=true;
}
}
dfs(,true,,);
dfs(,false,,);
printf("%d",ans);
}

正解以后附(本人还未提交测试代码)

Problem 2

1340. jumpcow(牛跳) (Standard IO)

时间限制: 1000 ms  空间限制: 131072 KB  具体限制  

Goto ProblemSet

题目描述

  John的奶牛们计划要跳到月亮上去。它们请魔法师配制了 P (1 <= P <=150,000)种药水,这些药水必需安原来的先后次序使用,但中间可以跳过一些药水不吃。每种药水有一个“强度”值 s ( 1 <= s <= 500 ),表示可以增强牛的跳跃能力。然而,药力的作用却是交替相反方向起作用,也就是说:当第奇数次吃药时,牛获得跳的更高的能力,而第偶数吃药时,却降低了跳高能力。在吃药前,牛的跳高能力当然为 0 。
   每种药只能吃一次,开始时为第1次吃药。
   请求出牛可能跳到的最高高度--最大跳跃能力。
 
 

输入

第一行:一个整数 P
下面P行:每行一个整数,表示按先后次序要吃的药水的“强度”。

输出

只一个整数,表示最大弹跳能力。
 

样例输入

 

样例输出

 
 

数据范围限制

 
 

提示

输入

8

7

2

1

8

4

3

5

6

去掉第2、4两种药水,
吃药为:
7,1,8,3,6;
最终能力为:
7-1+8-3+6=17

输出

17

    
 
 
 
 
服务器时间: Fri Aug 02 2019 18:27:32 GMT+0800 (中国标准时间)Fortuna OJ 项目
作者: moreDRD; 协力: twilightMcHobby
由 CodeIgniter / Bootstrap 驱动
Glyphicons 提供图标

思路:动态规划。

附上代码:

(TLE错误代码20分DFS)

#include <cstdio>
#include <iostream>
#define rr register
using namespace std;
int p,a[],ans;
int max(int a,int b)
{
if(a>b)
return a;
return b;
}
void dfs(rr int i,bool xz,bool zf,int sum)
{
if(i>p)
{
ans=max(ans,sum);
return;
}
if(xz)
{
if(zf)
sum+=a[i];
else
sum-=a[i];
zf=!zf;
}
dfs(i+,true,zf,sum);
dfs(i+,false,zf,sum);
}
int main()
{
scanf("%d",&p);
for(rr int i=;i<=p;i++)
scanf("%d",&a[i]);
dfs(,true,true,);
dfs(,false,true,);
printf("%d",ans);
}

正解(AC100分DP)

#include <cstdio>
#define rr register
int max(int a,int b)
{
if(a>b)
return a;
return b;
}
int main()
{
int p,a[],f[][];
scanf("%d",&p);
for(rr int i=;i<=p;i++)
scanf("%d",&a[i]);
f[][]=a[];
for(rr int i=;i<=p;i++)
{
f[i][]=max(f[i-][]+a[i],f[i-][]);
f[i][]=max(f[i-][]-a[i],f[i-][]);
}
printf("%d",f[p][]);
}

Problem 3

1341. water(水流) (Standard IO)

时间限制: 1000 ms  空间限制: 131072 KB  具体限制  

Goto ProblemSet

题目描述

全球气候变暖,小镇A面临水灾。于是你必须买一些泵把水抽走。泵的抽水能力可以认为是无穷大,但你必须把泵放在合适的位置,从而能使所有的水能流到泵里。小镇可以认为是N * M的矩阵。矩阵里的每个单元格都是一个‘a’- ‘z’小写字母,该小写字母表示该格子的高度,字母大的表示该单元格比较高,反之,表示该格子高度比较低。当前单元格的水可以流到上、下、左、右四个格子,但必须满足这些格子的高度是小于或者等于当前格子的高度。现在,给你一些N * M的矩阵,你至少要买多少个泵,才能把所有格子的水都能被抽走?

 

输入

 多组测试数据。
 第一行:K,表示有K组测试数据。 1 <= K <= 5.
 接下来有K组测试数据,每组测试数据格式如下:
     第一行:两个正数, N , M . 1 <= N, M <= 50,表示小镇的大小。
     接下来有N行,每行有M个小写字母,表示小镇的地图。

输出

共K行,每行对应一组数据。至少要买多少个泵,才能把所有格子的水都能抽走。

 

样例输入

 

样例输出

 
 

数据范围限制

 
 

提示

输入  

2
 5 5
 ccccc
 cbbbc
 cbabc
 cbbbc
 ccccc
 4 9
 cbabcbabc
 cbabcbabc
 cbabcbabc
 cbabcbabc

1
 11   11
 ccccccccccc
 caaaaaaaaac
 caaaaaaaaac
 caazpppzaac
 caapdddpaac
 caapdddpaac
 caapdddpaac
 caazpppzaac
 caaaaaaaaac
 caaaaaaaaac
 ccccccccccc

输出

1
2

 2
 
 
 
 
服务器时间: Fri Aug 02 2019 18:32:45 GMT+0800 (中国标准时间)Fortuna OJ 项目
作者: moreDRD; 协力: twilightMcHobby
由 CodeIgniter / Bootstrap 驱动
Glyphicons 提供图标

思路:搜索(DFS,BFS均可)

代码实现:(DFS100分)

#include <cstdio>
#include <iostream>
#include <cstring>
using namespace std;
int n,m;
char a[][];
bool bj[][];
int xi[]={,,-,};
int yi[]={,-,,};
void dfs(int x,int y)
{
bj[x][y]=true;
for(int i=;i<;i++)
{
int x1=x+xi[i];
int y1=y+yi[i];
if(x1<=n && x1> && y1<=m && y1> && bj[x1][y1]==false && a[x1][y1]>=a[x][y]){
dfs(x1,y1);
}
}}
int main()
{
int k=;
scanf("%d",&k);
while(k--)
{
memset(bj,false,sizeof bj);
scanf("%d %d",&n,&m);
for(int i=;i<=n;i++)
{
for(int j=;j<=m;j++)
cin>>a[i][j];
}
int ans=;
for(char c='a';c<='z';c++){
for(int i=;i<=n;i++){
for(int j=;j<=m;j++){
if(bj[i][j]==false && a[i][j]==c)
{
dfs(i,j);
ans++;
}
}
}
}
printf("%d\n",ans);
}
}

Problem 4

1342. cowtract(网络) (Standard IO)

时间限制: 1000 ms  空间限制: 131072 KB  具体限制  

Goto ProblemSet

题目描述

  Bessie受雇来到John的农场帮他们建立internet网络。农场有 N (2<= N <= 1,000)牛棚,编号为1..N。John之前已经勘测过,发现有 M (1<= M <= 20,000)条可能的连接线路,一条线路是连接某两个牛棚的。每条可能的线路都有一个建设费用 C (1<= C <=100,000)。John当然想花尽量少的钱,甚至克扣Bessie的工钱。
  Bessie发现了这点,很生气,决定给John捣乱。她要选择一些线路组成网,但费用却尽可能大。当然网络要能正常工作,也就是任意两个牛棚之间都是相互可以连通的,并且网络上不能有环,不然John会很容易发现的。
 请计算组建这种网络最多可能的费用。
 

输入

第一行:两个整数 N M
下面M行:每行3个整数 A,B,C。表示一个可能的线路要连接A、B两个牛棚,费用是C。

输出

只一行,一个整数,即花费最大的费用。如果不可能连接通所有牛棚,输出-1。
 

样例输入

 

样例输出

 
 

数据范围限制

 
 

提示

输入

5 8

1 2 3

1 3 7

2 3 10

2 4 4

2 5 8

3 4 6

3 5 2

4 5 17

17 + 8 + 10 + 7 = 42

输出

42

 
 
 
 
 
服务器时间: Fri Aug 02 2019 18:37:34 GMT+0800 (中国标准时间)Fortuna OJ 项目
作者: moreDRD; 协力: twilightMcHobby
由 CodeIgniter / Bootstrap 驱动
Glyphicons 提供图标

思路:最小生成树

代码实现:Unknow.

2019中山纪念中学夏令营-Day2[JZOJ]的更多相关文章

  1. 2019中山纪念中学夏令营-Day20[JZOJ] T1旅游详解

    2019中山纪念中学夏令营-Day20[JZOJ] 提高组B组 Team_B组 T1 旅游 Time Limits: 2000 ms  Memory Limits: 262144 KB Descrip ...

  2. 2019中山纪念中学夏令营-Day21[JZOJ]

    2019中山纪念中学夏令营-Day21[JZOJ] 提高组(B组模拟赛)Team_B (由于本人太弱,并没有订正完题目) (题解大部分是从官方题解文件上摘来的) 日常膜拜大神:じやゆん蒟蒻 正文部分: ...

  3. 2019中山纪念中学夏令营-Day9[JZOJ](第六次模拟赛)

    Begin (题目的排序方式:Unkown其实是按心情排的) 异或:(摘自百度百科) 异或(xor)是一个数学运算符.它应用于逻辑运算.异或的数学符号为“⊕”,计算机符号为“xor”.其运算法则为: ...

  4. 2019中山纪念中学夏令营-Day12[JZOJ]

    Begin (题目的排序方式:题号) 每期新姿势:(今天推荐一位巨佬)Cefola-Kiroxs 推荐知识:namespace的用法(本赛我的代码中将用到) 2019.08.12[NOIP普及组]模拟 ...

  5. 2019中山纪念中学夏令营-Day4[JZOJ]

    Begin (题目的排序方式:难易程度) 什么是对拍: 对拍是一种在写完程序后,验证自己程序是不是正解的比较方便的方法. 实现过程: 对同一道题,再打一个暴力程序,然后用一些大数据等跑暴力程序来进行验 ...

  6. 2019中山纪念中学夏令营-Day1[JZOJ]

    T1 题目描述: 1999. Wexley接苹果(apple) (File IO): input:apple.in output:apple.out 时间限制: 1000 ms  空间限制: 1280 ...

  7. 2019中山纪念中学夏令营-Day14 图论初步【dijkstra算法求最短路】

    Dijkstra是我学会的第一个最短路算法,为什么不先去学SPFA呢?因为我在luogu上翻到了一张比较神奇的图: 关于SPFA -它死了 以及网上还有各位大佬的经验告诉我:SPFA这玩意很容易被卡. ...

  8. 2019中山纪念中学夏令营-Day19 数论初步【GCD(最大公约数),素数相关】

    关于GCD的一些定理或运用的学习: 1. 2.二进制算法求GCD 思想:使得最后的GCD没有2(提前把2提出来) 代码实现: #include <cstdio> #define int l ...

  9. [小结] 中山纪念中学2018暑期训练小结(划掉)(颓废记)-Day10

    [小结] 中山纪念中学2018暑期训练小结(划掉)(颓废记)-Day10 各位看众朋友们,你们好,今天是2018年08月14日,星期二,农历七月初四,欢迎阅看今天的颓废联编节目 最近发生的灵异事件有 ...

随机推荐

  1. ngx_http_auth_request_module 第三方认证

    shell > vim /usr/local/nginx-1.10.2/conf/vhost/auth.conf # 这是第三方认证服务器,认证逻辑使用的 PHP 代码 server { lis ...

  2. OSI7层模型

    为什么来写一个osi7层模型的随便呐? 因为自己对osi模型一点不熟悉 只知道里面的协议 要学渗透必先学习osi 这是一个osi7层的大体图片 接下来我们会对每一层进行详细的解答 这是五层模型 接下来 ...

  3. 使用SpringBoot校验客户端传来的数据

    前端的数据校验都是辣鸡!后端天下第一! 很多时候我们后端需要前端传数据过来, 比如注册, 修改用户名, 修改密码等等.很可能有些用户就喜欢搞事, 喜欢发一大堆乱七八糟的数据到后端来, 甚至有些前端老哥 ...

  4. 快速理解arguments对象

    在js中一切都是对象,连函数也是对象,函数名其实是引用函数定义对象的变量. 1.什么是arguments? 这个函数体内的arguments非常特殊,实际上是所在函数的一个内置类数组对象,可以用数组的 ...

  5. Linux - 加密打包

    tar 加密打包 压缩 tar -czvf /path/to/file.tar.gz file 解压 tar -xzvf /path/to/file.tar.gz /path/to 加密压缩 tar ...

  6. Jdbc中大文本类型的处理

    Oracle中大文本数据类型, Clob    长文本类型   (MySQL中不支持,使用的是text) Blob    二进制类型 MySQL数据库, Text    长文本类型 Blob    二 ...

  7. phpStudy本地搭建wordpress教程

    一.启用phpStudy环境包 phpStudy简单易用,一键启动配置本地环境; 二.wordpress博客程序 登陆wordpress官网下载最新程序,解压后提取wordpress目录下全部文件到p ...

  8. c#根据配置文件反射

    由于项目中用到了反射,准备把各个类库都先写在配置文件中,然后读取配置文件,再对配置文件中配置的类库进行反射. 这样做的好处是各个类库保持独立,其中一个类库出现问题不会影响其他类库,更新项目时,只要更新 ...

  9. 2019.11.29 SAP SMTP郵件服務器配置 發送端 QQ郵箱

    今天群裏的小夥伴問了如何配置郵件的問題,隨自己在sap裏面配置了一個 1.    RZ10配置參數 a)       参数配置前,先导入激活版本 执行完毕后返回 b)      输入参数文件DEFAU ...

  10. 模拟SQLserver IO压力测试 工具编 SQLIOSIM

    描述 最近有业务需求需了解客户的服务器SQLserver 的IO情况,而不仅仅是通过系统计数器 了解硬盘的IO情况或者使用CrystalDiskMark或者Trace重播进行压力测试 .这时SQL S ...