一、本周ACM学习相关内容

  1. 学习了dfs和bfs —— 4小时
  2. 课上系统的学习了vector等stl函数的使用即注意事项—3小时

二、题数与耗时

师哥安排了12道题,做了五道(不包含比赛题);大概4个小时;

题解报告:

POJ - 2386 Lake Counting

很简单的dfs,遍历数组,找到w就dfs周围的八个点,直到递归结束;

#include<iostream>

#include<cstring>

#include<algorithm>

#include<cstdio>

using namespace std;

int m,n;

char a[1001][1001];

void DFS(int i,int j)

{

if(i>=0&&i<n&&j>=0&&j<m&&a[i][j]=='W'){

a[i][j] = '.';

DFS(i-1,j);DFS(i-1,j-1);DFS(i-1,j+1);DFS(i,j-1);DFS(i,j+1);DFS(i+1,j-1);DFS(i+1,j);DFS(i+1,j+1);}

}

int main()

{

int i,j,sum = 0;

cin>>n>>m;

memset(a,'0',sizeof(a));

for(i = 0;i<n;i++)

scanf("%s",a[i]);

for(i = 0;i<n;i++)

for(j = 0;j<m;j++)

if(a[i][j]=='W')

{

sum++;

DFS(i,j);

}

printf("%d\n",sum);

}

POJ - 1979 Red and Black

与上一题类似,不同的是递归到周围四个点即可,并且计数要在函数内

#include<iostream>

#include<cstdio>

#include<algorithm>

using namespace std;

int w,h,i,j;

int step;

int sx,sy;

char a[21][21];

void dfs(int x,int y)

{

if(x>=0&&x<h&&y>=0&&y<w&&a[x][y]=='.')

{

a[x][y] = '#';

step++;

dfs(x-1,y);dfs(x+1,y);dfs(x,y+1);dfs(x,y-1);

}

}

int main()

{

while(cin>>w>>h&&w!=0&&h!=0){

int flag = 0;

step = 0;

for( i = 0;i<h;i++)

scanf("%s",a[i]);

for( i = 0;i<h;i++){

for( j = 0;j<w;j++)

{

if(a[i][j]=='@')

{

a[i][j] = '.';

sx = i;

sy = j;

flag = 1;

break;

}

}if(flag == 1)

break;

}

dfs(sx,sy);

cout<<step<<endl;

}

}

Aizu - 0118 Property Distribution

与第一题一样

#include<iostream>

#include<string>

#include<cstdio>

using namespace std;

int w,h;

char a[101][101];

int res;

void dfs(int x,int y,char s)

{

char t;

if(x>=0&&x<h&&y>=0&&y<w&&a[x][y]==s){

t = a[x][y];

a[x][y] = 'O';

dfs(x+1,y,t);dfs(x-1,y,t);dfs(x,y+1,t);dfs(x,y-1,t);}

}

int main()

{

while(cin>>h>>w&&h!=0&&w!=0)

{int i,j;

res = 0;

for(i = 0;i<h;i++)

scanf("%s",a[i]);

for(i = 0;i < h;i++)

for(j = 0;j<w;j++)

{

if(a[i][j]!='O')

{

res++;dfs(i,j,a[i][j]);

}

}

cout<<res<<endl;

}

}

Aizu - 0033 Ball

暴力模拟即可,没有难度。。。。(严重怀疑是师哥为了给我们增长信心加的题)

#include<iostream>

#include<vector>

#include<cmath>

using namespace std;

int main()

{

int n;

cin>>n;

vector<int >a;

vector<int >b;

while(n--)

{

int flag = 0;

int i;

int num[10];

for(i = 0;i<=9;i++)

cin>>num[i];

a.push_back(0);

b.push_back(0);

for(i = 0;i<10;i++)

{

if(num[i]>a.back()||num[i]>b.back())

{

if(num[i]>a.back()&&num[i]<b.back())

{

a.push_back(num[i]);

}

else if(num[i]>b.back()&&num[i]<a.back())

{

b.push_back(num[i]);

}

else if(num[i]>a.back()&&num[i]>b.back())

{

if(a.back()>b.back())

a.push_back(num[i]);

else

b.push_back(num[i]);

}

if(i==9)

flag = 1;

}

else{

flag = 0;break;

}

}

if(flag == 1)

cout<<"YES"<<endl;

else

cout<<"NO"<<endl;

a.clear();b.clear();

}

}

Aizu - 0558 Cheese

说实话,这个题才体现出bfs的魅力和难懂性。。。。。。感谢张师姐

#include<iostream>

#include<queue>

#include<cstring>

using namespace std;

struct node{

int x,y;

int step;

node(){

step = 0;

}

};

int dx[4] = {0,0,1,-1};

int dy[4] = {1,-1,0,0};

char mp[1005][1005];//迷宫

int vis[1005][1005];//访问状态

int sx,sy;//起始位置;

int main()

{

int h,w,n;

cin>>h>>w>>n;//输入

for(int i = 0;i < h;i++)

{

for(int j = 0;j < w;j++)

{

cin>>mp[i][j];

if(mp[i][j]=='S')

{

sx = i;sy = j;

}

}

}//生成地图并寻找起始点

int ans = 0;//声明结果

queue <node> q;

for(int i = 1;i <= n;i++)

{

memset(vis, 0, sizeof(vis));//重置访问状态;

node now,next;

now.x = sx;

now.y = sy;

vis[sx][sy] = 1;

q.push(now);

while(q.empty()==false)

{

now = q.front();

q.pop();

if(mp[now.x][now.y] == '0'+i)

{

sx = now.x;

sy = now.y;

ans = ans+now.step;

break;

}//吃到了

for(int j = 0;j < 4;j++)

{

int xx = now.x+dx[j];

int yy = now.y+dy[j];

if(xx>=0&&xx<h&&yy>=0&&yy<w&&mp[xx][yy]!='X'&&vis[xx][yy]==0)

{

vis[xx][yy] = 1;

next.x = xx;

next.y = yy;

next.step = now.step+1;

q.push(next);

}

}

}

while(!q.empty())

q.pop();

}

cout<<ans<<endl;

}

三、比赛情况

3.14的比赛有事请假了

四、锻炼情况

体育作业:每周1200米

2020.3.9 ~ 2020.3.15 ACM训练周总结的更多相关文章

  1. 计蒜客 ACM训练联盟周赛 第一场 Alice和Bob的Nim游戏 矩阵快速幂

    题目描述 众所周知,Alice和Bob非常喜欢博弈,而且Alice永远是先手,Bob永远是后手. Alice和Bob面前有3堆石子,Alice和Bob每次轮流拿某堆石子中的若干个石子(不可以是0个), ...

  2. 寒假的ACM训练(一)

    今天开始ACM训练,选择了刘汝佳的<挑战编程>,暂时算是开始了. 测评的网址: http://www.programming-challenges.com 第一个题目是水题啦.3n+1. ...

  3. 计蒜客 28449.算个欧拉函数给大家助助兴-大数的因子个数 (HDU5649.DZY Loves Sorting) ( ACM训练联盟周赛 G)

    ACM训练联盟周赛 这一场有几个数据结构的题,但是自己太菜,不会树套树,带插入的区间第K小-替罪羊套函数式线段树, 先立个flag,BZOJ3065: 带插入区间K小值 计蒜客 Zeratul与Xor ...

  4. 2014暑假ACM训练总结

    2014暑假ACM训练总结报告 匆匆之中,一个暑假又过去了,在学校训练的这段日子真的是感觉日子过得好快啊! 时光如箭,日月如梭! 匆忙的学习之中一个暑假就这样结束了,现在就来写一些总结吧,供自己以后阅 ...

  5. 计蒜客 ACM训练联盟周赛 第一场 Christina式方格取数 思维

    助手Christina发明了一种方格取数的新玩法:在n*m的方格棋盘里,每个格子里写一个数.两个人轮流给格子染色,直到所有格子都染了色.在所有格子染色完后,计算双方的分数.对于任意两个相邻(即有公共边 ...

  6. 计蒜客 ACM训练联盟周赛 第一场 从零开始的神棍之路 暴力dfs

    题目描述 ggwdwsbs最近被Zeratul和Kyurem拉入了日本麻将的坑.现在,ggwdwsbs有13张牌,Kyurem又打了一张,加起来有14张牌.ggwdwsbs想拜托你帮他判断一下,这14 ...

  7. [2020.03]Unity ML-Agents v0.15.0 环境部署与试运行

    一.ML-Agents简介 近期在学习Unity中的机器学习插件ML-Agents,做一些记录,用以简单记录或交流学习. 先简单说一下机器学习使用的环境场景:高视觉复杂度(Visual Complex ...

  8. [每日一题2020.06.13]leetcode #739 #15 单调栈 双指针查找

    739 每日温度 ( 单调栈 ) 题目 : https://leetcode-cn.com/problems/daily-temperatures/ 题意 : 找到数组每一个元素之后第一个大于它的元素 ...

  9. ACM训练小结-2018年6月15日

    今天题目情况如下:A题:给出若干条边的边长,问这些边按顺序能否组成一个凸多边形,并求出这个多边形的最小包含圆.答题情况:无思路.正解(某种):第一问很简单.对第二问,如果R大于可行的最小R,那么按照放 ...

  10. ACM训练赛:第20次

    这次的题思维都很强,等之后的考试结束会集中精力重新训练一些思维题. A - A simple question CodeForces - 520B 思路: 直接看的话,很容易发现如果 \(n > ...

随机推荐

  1. win10格式化U盘提示没有权限执行此操作

    解决办法参考:http://www.tpbz008.cn/post/766.html 1.gpedit.msc 2.展开计算机配置,管理模板.展开系统.选中可移动存储访问 3.所有可移动存储类:拒绝所 ...

  2. Python——01.环境及安装

    Python介绍 -- Python是解释型,面向对象的语言,程序结构简洁,清晰 -- Python解释器分类: CPython(官方解释器):用C语言编写的Python解释器 PyPy:用Pytho ...

  3. unity GetComponent在android端获取对象错误

    PlayerObj pobj = go.GetComponent<PlayerObj>(); if (pobj && pobj.IsMyTeam()) { marchAct ...

  4. Linux下mysql安装教程

    一 环境准备 1.检查是否已经安装过mysql,执行命令 [root@localhost /]# rpm -qa | grep mysql 从执行结果,可以看出我们已经安装了mysql-libs-5. ...

  5. Java 18-方法 认识方法与方法定义

    1.认识方法 1)什么是方法 Java方法是语句的集合,它们在一起执行一个功能; 方法是解决一类问题的步骤的有序组合; 方法一般包含于类中; 方法在程序中被创建,在其他地方被引用2 2)方法的有点 使 ...

  6. SATA硬盘的数据和电源接口定义(转)

    现在 SATA设备越来越普及,包括STAT硬盘和光驱基本都已经是 SATA接口的了,以前的老式电源输出接口一般都是20针供主板加上4针的电源供硬盘也就是说以前的电脑电源给硬盘供电没有设计15针 SAT ...

  7. Solution - ARC152D Halftree

    首先 \(n\) 为偶数时无解,这是显然的,因为一次加两条边,总边数一定是偶数. 下面我们证明 \(n\) 为奇数时一定有解,直接进行构造. 首先将每一个点编号加上 \(k\) 再模 \(n\) 的答 ...

  8. tomcat 1 - Servlet 容器

    Socket socket = new Socket ( "yahoo.com", 80); OutputStream os = socket.getOutputStream(); ...

  9. Oracle dump文件的一些经验

    dump文件对于DBA而言再平常不过了.不过因为dump文件是二进制文件,我们平时使用中不太关注.再导入dump文件时有很多细节和技巧是值得注意的. 1.查看dump文件的一些基本信息 strings ...

  10. Carthage 使用介绍

    1.安装 Carthage 安装 brew install carthage 检测当前版本 carthage version 升级至最新版本 brew upgrade carthage 2.如果更新出 ...