2018 Spring Single Training B (uva 572,HihoCoder 1632,POJ 2387,POJ 2236,UVA 10054,HDU 2141)
这场比赛可以说是灰常的水了,涨信心场??
今下午义务劳动,去拿着锄头发了将近一小时呆,发现自己实在是干不了什么,就跑到实验室打比赛了~
之前的比赛补题补了这么久连一场完整的都没补完,结果这场比完后一小时连题解都出来了···
A-烤肉拌饭 ( uva 572)
就是求联通块的数量啊,刚学dfs的时候做的那种!
- #include <cstdio>
- #include <algorithm>
- #include <cstring>
- #include <iostream>
- #include <queue>
- using namespace std;
- const int maxn=+;
- const int dx[]={,-,,-,,-,,};
- const int dy[]={,,,,-,-,,-};
- char G[maxn][maxn];
- int vis[maxn][maxn];
- int n,m;
- int ans;
- void dfs(int x,int y){
- vis[x][y]=;
- for(int i=;i<;i++){
- int nx=x+dx[i];
- int ny=y+dy[i];
- if(nx>=&&nx<=n&&ny>=&&ny<=m&&G[nx][ny]=='@'&&!vis[nx][ny]){
- dfs(nx,ny);
- }
- }
- return ;
- }
- int main(){
- while(scanf("%d%d",&n,&m)&&n&&m){
- memset(vis,,sizeof(vis));
- ans=;
- for(int i=;i<=n;i++){
- for(int j=;j<=m;j++){
- scanf(" %c",&G[i][j]);
- }
- }
- for(int i=;i<=n;i++){
- for(int j=;j<=m;j++){
- if(!vis[i][j]&&G[i][j]=='@'){
- ans++;
- dfs(i,j);
- }
- }
- }
- cout<<ans<<endl;
- }
- return ;
- }
B-麻辣香锅 HihoCoder - 1632
模拟,emmm模拟可以提高代码能力??
C-啵啵鱼 poj2387
是个很裸的最短路,一个spfa或者dijsktra就可以
- #include <cstdio>
- #include <algorithm>
- #include <cstring>
- #include <iostream>
- #include <queue>
- using namespace std;
- const int maxn=+;
- const int maxm=+;
- const int INF=;
- typedef long long LL;
- int head[maxn],Next[maxm],to[maxm];
- LL val[maxm];
- int sz;
- int n,m;
- void add_edge(int a,int b,LL w){
- ++sz;
- val[sz]=w;
- to[sz]=b;
- Next[sz]=head[a];
- head[a]=sz;
- }
- LL d[maxn];
- int spfa(int s){
- for(int i=;i<=n;i++)d[i]=INF;
- int vis[maxn];
- memset(vis,,sizeof(vis));
- queue<int>q;
- q.push(s);
- vis[s]=;
- d[s]=;
- while(!q.empty()){
- int u=q.front();q.pop();vis[u]=;
- for(int i=head[u];i;i=Next[i]){
- int v=to[i];
- if(d[v]>d[u]+val[i]){
- d[v]=d[u]+val[i];
- if(!vis[v]){
- vis[v]=;
- q.push(v);
- }
- }
- }
- }
- return d[];
- }
- int main(){
- sz=;
- memset(head,,sizeof(head));
- scanf("%d%d",&m,&n);
- int a,b;LL c;
- for(int i=;i<=m;i++){
- scanf("%d %d%lld",&a,&b,&c);
- // cout<<a<<" "<<b<<" "<<c<<endl;
- add_edge(a,b,c);
- add_edge(b,a,c);
- }
- cout<<spfa(n);
- return ;
- }
D-海底捞 POJ2236
卢老师一句话点醒梦中人,直接并查集就可以~
- #include <cstdio>
- #include <algorithm>
- #include <iostream>
- #include <cstring>
- using namespace std;
- const int maxn=+;
- int n,d;
- int a,b;
- char c;
- int p[maxn],vis[maxn];
- struct Node{
- int x,y;
- }node[maxn];
- int find(int x){
- return p[x]==x?x:p[x]=find(p[x]);
- }
- bool dist(Node A,Node B){
- if((A.x-B.x)*(A.x-B.x)+(A.y-B.y)*(A.y-B.y)<=d*d)
- return true;
- return false;
- }
- int main(){
- scanf("%d%d",&n,&d);
- for(int i=;i<=n;i++){
- scanf("%d%d",&node[i].x,&node[i].y);
- }
- for(int i=;i<=n;i++)p[i]=i;
- while(scanf(" %c",&c)!=EOF){
- if(c=='O'){
- scanf("%d",&a);
- vis[a]=;
- for(int i=;i<=n;i++){
- if(vis[i]&&i!=a&&dist(node[a],node[i])){
- // cout<<a<<"-->"<<i<<endl;
- int x=find(a),y=find(i);
- if(x!=y)p[x]=y;
- }
- }
- }
- if(c=='S'){
- scanf("%d%d",&a,&b);
- int x=find(a),y=find(b);
- //cout<<":"<<x<<y<<endl;
- if(x==y){
- printf("SUCCESS\n");
- }else{
- printf("FAIL\n");
- }
- }
- }
- return ;
- }
E-黄焖鸡 uva10054
这个题以前做过,欧拉回路,注意打印的时候逆序输出
- #include <cstdio>
- #include <algorithm>
- #include <cstring>
- #include <iostream>
- #include <queue>
- using namespace std;
- const int maxn=+;
- int T;
- int G[maxn][maxn];
- int n;
- int deg[maxn];
- int a,b;
- int M;
- int p[maxn];
- int find(int x){
- return p[x]==x?x:find(p[x]);
- }
- void dfs(int u){
- for(int i=;i<=M;i++){
- if(G[u][i]){
- G[u][i]--;
- G[i][u]--;
- dfs(i);
- cout<<i<<" "<<u<<endl;
- }
- }
- return;
- }
- int main(){
- scanf("%d",&T);
- for(int t=;t<=T;t++){
- if(t!=)cout<<""<<endl;
- memset(G,,sizeof(G));
- memset(deg,,sizeof(deg));
- printf("Case #%d\n",t);
- M=-;
- scanf("%d",&n);
- for(int i=;i<=;i++)p[i]=i;
- for(int i=;i<=n;i++){
- scanf("%d%d",&a,&b);
- M=max(M,max(a,b));
- G[a][b]++;
- G[b][a]++;
- deg[a]++;
- deg[b]++;
- int x=find(a),y=find(b);
- if(x!=y)p[x]=y;
- }
- bool judge=;
- for(int i=;i<=M;i++){
- if(deg[i]){
- if(find(i)!=find(M)||deg[i]%){
- judge=;
- break;
- }
- }
- }
- if(!judge){
- cout<<"some beads may be lost"<<endl;
- }else{
- for(int i=;i<=M;i++)
- dfs(i);
- }
- }
- return ;
- }
F- 减肥成功指日可待 hdu2141
用set或者二分。但是set再G++下会MLE必须要选择C++才能AC,雾···
- #include <cstdio>
- #include <algorithm>
- #include <cstring>
- #include <iostream>
- #include <set>
- #include <vector>
- using namespace std;
- const int maxn=+;
- typedef long long LL;
- int A,B,C,s,x;
- LL a[maxn],b[maxn],c[maxn];
- int kase;
- int main(){
- while(scanf("%d%d%d",&A,&B,&C)!=EOF){
- kase++;
- set<LL>S;
- printf("Case %d:\n",kase);
- for(int i=;i<=A;i++){
- scanf("%lld",&a[i]);
- }
- for(int i=;i<=B;i++){
- scanf("%lld",&b[i]);
- }
- for(int i=;i<=C;i++){
- scanf("%lld",&c[i]);
- }
- for(int i=;i<=A;i++){
- for(int j=;j<=B;j++){
- //for(int l=1;l<=C;l++){
- LL X=a[i]+b[j];
- if(!S.count(X))
- S.insert(X);
- // }
- }
- }
- scanf("%d",&s);
- LL x;
- for(int i=;i<=s;i++){
- scanf("%lld",&x);
- bool ok=;
- for(int i=;i<=C;i++){
- LL pos=x-c[i];
- //if(pos<0)continue;
- if(S.count(pos)){
- ok=;
- break;
- }
- }
- //if(S.count(x))cout<<"YES"<<endl;
- if(ok)cout<<"YES"<<endl;
- else
- cout<<"NO"<<endl;
- }
- }
- return ;
- }
2018 Spring Single Training B (uva 572,HihoCoder 1632,POJ 2387,POJ 2236,UVA 10054,HDU 2141)的更多相关文章
- UVA 572 Oil Deposits油田(DFS求连通块)
UVA 572 DFS(floodfill) 用DFS求连通块 Time Limit:1000MS Memory Limit:65536KB 64bit IO Format: ...
- UVA 572 -- Oil Deposits(DFS求连通块+种子填充算法)
UVA 572 -- Oil Deposits(DFS求连通块) 图也有DFS和BFS遍历,由于DFS更好写,所以一般用DFS寻找连通块. 下述代码用一个二重循环来找到当前格子的相邻8个格子,也可用常 ...
- 我的spring cloud项目历程(2018.3~2018.9)
前言 今天是9月17日,趁着山竹的临幸,得以在家里舒适的办公.项目从3月底开始,至今刚好半年.抽几十分钟,总结下半年的历程.对后面的项目,应该也有一点帮助吧. 学习前的七个问题 项目开始前,由于某些特 ...
- 2018 Multi-University Training Contest 10 CSGO(HDU - 6435)(最远曼哈顿距离)
有 n 种主武器,m 种副武器.每种武器有一个基础分数k种属性值 X[i] . 选出一种主武器 mw 和一种副武器 sw,使得两种武器的分数和 + 每个属性的差值尽量大.(参考下面的式子) 多维的最远 ...
- Spring MVC 学习总结(二)——控制器定义与@RequestMapping详解
一.控制器定义 控制器提供访问应用程序的行为,通常通过服务接口定义或注解定义两种方法实现. 控制器解析用户的请求并将其转换为一个模型.在Spring MVC中一个控制器可以包含多个Action(动作. ...
- Spring MVC 学习总结(一)——MVC概要与环境配置
一.MVC概要 MVC是模型(Model).视图(View).控制器(Controller)的简写,是一种软件设计规范,用一种将业务逻辑.数据.显示分离的方法组织代码,MVC主要作用是降低了视图与业务 ...
- 2015年11月30日 spring初级知识讲解(一)装配Bean
序,Spring的依赖注入是学习spring的基础.IOC为控制反转,意思是需要的时候就由spring生成一个,而不是先生成再使用. 写在前面 Spring提供面向接口编程,面向接口编程与依赖注入协作 ...
- Spring常见面试问题 (转)
Spring 1. Spring工作机制及为什么要用?Spring 是一个开源框架,是为了解决企业应用程序开发复杂性而创建的.Spring既是一个AOP框架,也是一IOC容器.SpringFramew ...
- Spring MVC 学习总结(九)——Spring MVC实现RESTful与JSON(Spring MVC为前端提供服务)
很多时候前端都需要调用后台服务实现交互功能,常见的数据交换格式多是JSON或XML,这里主要讲解Spring MVC为前端提供JSON格式的数据并实现与前台交互.RESTful则是一种软件架构风格.设 ...
随机推荐
- golang日期转字符串,仿照C#中的日期格式结构体
1.日期格式集合.日期转字符串方法 package util import ( "strings" "time" ) //日期格式:模仿java中的结构体 ty ...
- I.MX6 AR8031 寄存器操作
/*************************************************************************** * I.MX6 AR8031 寄存器操作 * ...
- HihoCoder 1104 : Suzhou Adventure(树形DP)
Suzhou Adventure 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 Little Hi is taking an adventure in Suzhou n ...
- HihoCoder1620: 股票价格3 (单调队列 or DP)
股票价格3 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi最近在关注股票,为了计算股票可能的盈利,他获取了一只股票最近N天的价格A1~AN. 小Hi想知道,对于第 ...
- 更新pip
python -m pip install pip --upgrade pip要保持最新的,才可以去下载最新的其他的第三方包
- django的多对一,一对一,多对多关系
from django.db import models class Publisher(models.Model): name = models.CharField(max_length=30) a ...
- windows调试本地启动的tomcat
我们一般都通过Eclipse进行tomcat的本地调试,但有些特殊情况下需要直接本地启动tomcat(进入tomcat的bin目录下执行startup.bat),此时我们可以利用类似远程调试模式的方式 ...
- Linux LED字符设备驱动
// 申请IO资源 int gpio_request(unsigned gpio, const char *label); // 释放IO资源 void gpio_free(unsigned gpio ...
- PHP 16 个编程法则
HP是最好的编程语言.对于PHP开发者来说,掌握一些编程法则是十分重要的.而在PHP中,以双下划线(__)开头的方法称为魔术方法,它们扮演着非常重要的角色. 常用的魔术方法包括: -__constru ...
- ubuntu 环境变量配置
1.vim /etc/environment 2.vim /etc/profile export JAVA_HOME=/opt/jdk1.6.0_45PATH=$JAVA_HOME/bin:/pub/ ...