D11
=-=感觉今天的题目好难...
主要是没有碰到过,所以会觉得不懂怎么写..
其实现在想想,T1,T2,T3其实都好水..T1其实没有做过还真不会,有做过的话就是个大水题了
T2找最小环..超级裸的,但是自己不会打=-=
T3直接FLOYD...+判断障碍物是否有在同一条线上
今天按理来说只有T4会比较难一些..DP+贪心
T1:模拟+数学思想
- #include<cstdio>
- #include<cstring>
- #include<algorithm>
- using namespace std;
- int d,n,m,k,t;
- int minx=123456,miny=123456,sum=123456;
- int ansx[10001],ansy[10001],tot[1001][1001],a[100001],b[100001];
- int main(){
- freopen("manhattan.in","r",stdin);
- freopen("manhattan.out","w",stdout);
- scanf("%d%d",&d,&n);
- for(int i=1;i<=n;i++){
- scanf("%d%d",&a[i],&b[i]);
- if(a[i]<minx) minx=a[i];
- if(b[i]<miny) miny=b[i];
- }
- for(int i=1;i<=n;i++){
- t=(a[i]-minx)%d+1;//这一段是关键
- k=(b[i]-miny)%d+1;//就是%d看看是否要拆除
- ansx[t]++;//记录个数
- ansy[k]++;
- tot[t][k]++;
- }
- for(int i=1;i<=d;i++)
- for(int j=1;j<=d;j++){//横坐标上要拆的个数+纵坐标上的-重复算的
- if(ansx[i]+ansy[j]-tot[i][j]<sum) sum=ansx[i]+ansy[j]-tot[i][j];
- }
- printf("%d",sum);
- return 0;
- }
T2:裸的最小环
网上的模板代码简直在逗我..坑死我了
后面翻了翻书,发现代码很简单明了的..
主要的部分是
- for (int k=1; k<=n; ++k)
- {
- for (int i=1; i<k; ++i)
- for (int j=i+1; j<k; ++j)
- ans=Min(ans,f[i][j]+g[j][k]+g[k][i]);//个人感觉是在找环吧
- for (int i=1; i<=n; ++i)
- for (int j=1; j<=n; ++j)
- if ((i!=j)&&(j!=k)&&(i!=k))
- f[i][j]=Min(f[i][k]+f[k][j],f[i][j]);//FLOYD求最短路
- }
自己略理解了一下..或许也不是特别正确吧
有时间好好的刷几题试试看好了
附上代码:
- #include<iostream>
- #include<cstring>
- #include<cstdio>
- #include<cmath>
- #include<algorithm>
- using namespace std;
- int g[1001][1001],f[1001][1001];
- int Min(int a,int b) { return a<b?a:b; }
- int main ()
- {
- freopen("heart.in","r",stdin);
- freopen("heart.out","w",stdout);
- int n,m;
- memset(g,27,sizeof(g));
- memset(f,27,sizeof(f));
- scanf("%d%d",&n,&m);
- for (int i=1; i<=m; ++i)
- {
- int x,y;
- scanf("%d%d",&x,&y);
- scanf("%d",&g[x][y]);
- g[y][x]=g[x][y];
- f[x][y]=f[y][x]=g[x][y];
- }
- int ans=21474836;
- for (int k=1; k<=n; ++k)
- {
- for (int i=1; i<k; ++i)
- for (int j=i+1; j<k; ++j)
- ans=Min(ans,f[i][j]+g[j][k]+g[k][i]);
- for (int i=1; i<=n; ++i)
- for (int j=1; j<=n; ++j)
- if ((i!=j)&&(j!=k)&&(i!=k))
- f[i][j]=Min(f[i][k]+f[k][j],f[i][j]);
- }
- if (ans==21474836)
- printf("He will never come back.");
- else printf("%d",ans);
- fclose(stdin); fclose(stdout);
- }
T3:floyd求最短路问题
其实这一题我看题的第一时间有想到求最短路问题,但是一想到要判断是否有障碍物这个细节,就各种不想打
=-=这应该算是我之前的一种烦躁的病吧...一定要改过来啊..
其实我要是真打起来的话,极有可能用DIJK..什么算法求最短路,上面的那个细节也不一定处理得正确->或许当时就是这么想的嗯!
看了别人的程序之后发现这里的细节处理非常简单:
- for(int i=1;i<=m;i++){
- scanf("%d%d",&x2,&y2);
- for(int j=0;j<=n;j++)
- for(int k=0;k<j;k++){
- double a,b,c,d;
- a=abs(x[j]-x[k]);
- b=abs(y[j]-y[k]);
- c=abs(x[j]-x2);
- d=abs(y[j]-y2);
- if((b/a==d/c) && Max(x[j],x[k])>=x2 && Min(x[j],x[k])<=x2 && Max(y[j],y[k])>=y2 && Min(y[j],y[k])<=y2)
- dis[j][k]=dis[k][j]=INF;
- }
- }
在判断完斜率是否相等之后,看看那个障碍物是否在两个端点之间即可..
感觉这个方法很常用到..MARK一下..
附上完整代码:
- #include<cstdio>
- #include<cstring>
- #include<cmath>
- #include<algorithm>
- using namespace std;
- const int INF=123456789;
- int x0,y0,n,m,x2,y2;
- double dis[1001][1001];
- int x[10001],y[10001];
- int Min(int a,int b)
- {
- return a<b?a:b;
- }
- int Max(int a,int b)
- {
- return a<b?b:a;
- }
- int main(){
- freopen("brazil.in","r",stdin);
- freopen("brazil.out","w",stdout);
- memset(dis,63,sizeof(dis));
- scanf("%d%d%d%d",&x0,&y0,&n,&m);
- for(int i=1;i<=n;i++){
- scanf("%d%d",&x[i],&y[i]);
- dis[i][0]=sqrt((x[i]-x0)*(x[i]-x0)+(y[i]-y0)*(y[i]-y0))*2;
- for(int j=1;j<i;j++)
- dis[i][j]=dis[j][i]=sqrt((x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j]));
- }
- for(int i=1;i<=m;i++){
- scanf("%d%d",&x2,&y2);
- for(int j=0;j<=n;j++)
- for(int k=0;k<j;k++){
- double a,b,c,d;
- a=abs(x[j]-x[k]);
- b=abs(y[j]-y[k]);
- c=abs(x[j]-x2);
- d=abs(y[j]-y2);
- if((b/a==d/c) && Max(x[j],x[k])>=x2 && Min(x[j],x[k])<=x2 && Max(y[j],y[k])>=y2 && Min(y[j],y[k])<=y2)
- dis[j][k]=dis[k][j]=INF;
- }
- }
- for(int k=2;k<=n;k++)
- for(int i=1;i<=n;i++)
- for(int j=0;j<=n;j++){
- if(i!=j && j!=k && i!=k)
- dis[i][j]=Min(dis[i][j],dis[i][k]+dis[k][j]);
- }
- printf("%.0lf",dis[1][0]);
- return 0;
- }
顺便提一下floyd的一个小地方..
我不懂为什么一直会忘记掉dis[i][j]记录的是第i个点到第j个点的距离=-=
不要有一天傻逼打错了嗯
T4:DP+贪心
=-=不知道这样的T4自己什么时候才能改完!
HPY都改完了!你居然连那个妹纸都不如!你就是个傻逼傻逼傻逼..
D11的更多相关文章
- D11——C语言基础学PYTHON
C语言基础学习PYTHON——基础学习D11 20180908内容纲要: 1.RabbitMQ消息队列 (1)RabbitMQ安装 (2)Rabbits示例 模式一:fanout 模式二:direct ...
- 预科班D11
2020.09.21星期一 预科班D11 学习内容: 一.基本数据类型及内置方法 1.整形int及浮点型float + - * / // ** % > < >= <= 2.字符 ...
- 正式班D11
2020.10.20星期二 正式班D11 bash解释器交互式环境特性 命令和文件自动补全(Tab只能补全命令和文件) 快捷键 CTRL+C ==>终止前台运行的程序 CTRL+D ==> ...
- 暑假集训D11总结
%dalao 今天某学长来讲一个极其高深的数据结构——线段树(woc哪里高深了),然而并没有时间整理笔记= =,所以明天在扔笔记咯= = 考试 今天考试,一看数据范围,woc暴力分给的真足,然后高高兴 ...
- D11 列表 list 元祖 字典dict
取值 name = "alexdfg" print(name[3:5]) 取出 ex name = "alexdfg" print(name[3]) 取出e 列 ...
- 《转载》PAT 习题
博客出处:http://blog.csdn.net/zhoufenqin/article/details/50497791 题目出处:https://www.patest.cn/contests/pa ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- PHP执行文档操作
1.POWINTPOINT系列 之前参与过一个商城的项目,里面有将excel 导出的功能,但是如果要弄成PPT的我们应该怎么办呢?PHP是属于服务器端的 总不能在里面装个Powintpoint吧.于是 ...
- CSS-学习笔记三
绝对定位:1. 脱离了文档流,没有浮动效果2. 默认情况下,设置了绝对定位的块,它的Top,left是相对于浏览器的3. 当给设置了绝对定位的块的父元素设置定位的时候(绝对.相对.固定), 那么 ...
随机推荐
- 网络资源(7) - JAX-WS视频
2014_08_25 http://v.youku.com/v_show/id_XNjMzNDcyMTk2.html 基于JAX-WS编程模型的WebService 1. @WebService注释类 ...
- English is very important!
Well, as a college student,I haven't realized how important the English is . But as a web programmer ...
- android ndk通过遍历和删除文件
在做移动开发过程,难免有些本地文件管理操作.例如,很常见app随着微博.微信要清除缓存功能,此功能是走app文件夹.然后删除所有缓存文件.使用java的File类能够实现本地文件遍历及删 ...
- 隐藏Console形式无效(继续1)
[2014/10/19 23:57 ] :由port主机遥控. 该程序的执行后,计划自己主动开放之机999port,其他计算机将能够通过999port机器的操作. 程序中使用的到的命令: telne ...
- poj 1068 Parencodings 模拟
进入每个' ) '多少前' ( ', 我们力求在每' ) '多少前' ) ', 我的方法是最原始的图还原出来,去寻找')'. 用. . #include<stdio.h> #incl ...
- php exit、return、break、continue之间的差别,具体介绍
相信大家在php开发中有几个经常使用的停止程序和循环的keyword的误区( exit.return.break.continue) exit 退出全部脚本,是个函数 return 语言结构的使用方法 ...
- MVC验证08-jQuery异步验证
原文:MVC验证08-jQuery异步验证 本文主要体验通过jQuery异步验证. 在很多的教材和案例中,MVC验证都是通过提交表单进行的.通过提交表单,可以很容易获得验证出错信息.因为,无论是客户端 ...
- HTML5实现涂鸦板
原文:HTML5实现涂鸦板 最近闲的,看了看html5,强大的绘图功能让我惊奇,于是,写了个小玩意---涂鸦板,能实现功能有:画画,改色,调整画笔大小 html5的绘图可以分为点,线,面,圆,图片等, ...
- 请确保在编译时已将“AjaxControlToolkit.Properties.Resources.NET4.resources”正确嵌入或链接到程序集“AjaxControlToolkit”
原文:请确保在编译时已将"AjaxControlToolkit.Properties.Resources.NET4.resources"正确嵌入或链接到程序集"AjaxC ...
- linux 下一个 jira-6.3.6 组态 皴 翻译 迁移数据库
每一个版本号翻译包下载 https://translations.atlassian.com/dashboard/download jira下载地址 https://www.atlassian.c ...