=-=感觉今天的题目好难...

主要是没有碰到过,所以会觉得不懂怎么写..

其实现在想想,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的更多相关文章

  1. D11——C语言基础学PYTHON

    C语言基础学习PYTHON——基础学习D11 20180908内容纲要: 1.RabbitMQ消息队列 (1)RabbitMQ安装 (2)Rabbits示例 模式一:fanout 模式二:direct ...

  2. 预科班D11

    2020.09.21星期一 预科班D11 学习内容: 一.基本数据类型及内置方法 1.整形int及浮点型float + - * / // ** % > < >= <= 2.字符 ...

  3. 正式班D11

    2020.10.20星期二 正式班D11 bash解释器交互式环境特性 命令和文件自动补全(Tab只能补全命令和文件) 快捷键 CTRL+C ==>终止前台运行的程序 CTRL+D ==> ...

  4. 暑假集训D11总结

    %dalao 今天某学长来讲一个极其高深的数据结构——线段树(woc哪里高深了),然而并没有时间整理笔记= =,所以明天在扔笔记咯= = 考试 今天考试,一看数据范围,woc暴力分给的真足,然后高高兴 ...

  5. D11 列表 list 元祖 字典dict

    取值 name = "alexdfg" print(name[3:5]) 取出 ex name = "alexdfg" print(name[3]) 取出e 列 ...

  6. 《转载》PAT 习题

    博客出处:http://blog.csdn.net/zhoufenqin/article/details/50497791 题目出处:https://www.patest.cn/contests/pa ...

  7. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  8. PHP执行文档操作

    1.POWINTPOINT系列 之前参与过一个商城的项目,里面有将excel 导出的功能,但是如果要弄成PPT的我们应该怎么办呢?PHP是属于服务器端的 总不能在里面装个Powintpoint吧.于是 ...

  9. CSS-学习笔记三

    绝对定位:1. 脱离了文档流,没有浮动效果2. 默认情况下,设置了绝对定位的块,它的Top,left是相对于浏览器的3. 当给设置了绝对定位的块的父元素设置定位的时候(绝对.相对.固定),    那么 ...

随机推荐

  1. User、Role、Permission数据库设计ABP

    ABP 初探 之User.Role.Permission数据库设计 (EntityFramework 继承的另一种使用方法) 最近群里(134710707)的朋友都在讨论ABP源码,我把最近学习的内容 ...

  2. HTML5使用和实战分析HTML5 WebSocket API

    通过引入一个简单的界面(请参见下面的列表),开发替代技术,由于长轮询和"永远框架,从而进一步减少延迟. 后台代码 [Constructor(in DOMString url, optiona ...

  3. CSS定位:几种类型的position定位的元素

    当人们刚接触布局的时候都比较倾向于使用定位的方式.因为定位的概念看起来好像比较容易掌握.表面上你确切地指定了一个块元素所处的位置那么它就会坐落于那里.可是定位比你刚看到的时候要稍微复杂一点.对于定位来 ...

  4. javascript利用map,every,filter,some,reduce,sort对数组进行最优化处理

    案例: var scoresTable=[ {id:11,name:"小张",score:80}, {id:22,name:"小王",score:95}, {i ...

  5. jquery跨域请求解决方案(我们寻找,我还没有添加验证)

    http://www.3lian.com/edu/2014/02-10/127921.html 本篇文章仅仅要是对jquery ajax跨域解决方法(json方式)进行了介绍,须要的朋友能够过来參考下 ...

  6. Contoso 大学 - 使用 EF Code First 创建 MVC 应用,实例演练

    Contoso 大学 Web 示例应用演示了如何使用 EF 技术创建 ASP.NET MVC 应用.示例中的 Contoso 大学是虚构的.应用包括了类似学生注册.课程创建以及教师分配等功能. 这个系 ...

  7. css3简单几步画一个乾坤图

    原文:[原创]css3简单几步画一个乾坤图 效果如上,鼠标移上去会有动画. 代码如下非常简单: <html> <head> <style> .outer{heigh ...

  8. HTML5多图片拖拽上传带进度条

    前言 昨天利用css2的clip属性实现了网页进度条觉得还不错,但是很多情况下,我们在那些时候用进度条呢,一般网页加载的时候如果有需要可以用,那么问题就来了,怎么才算整个加载完毕呢,是页面主要模块加载 ...

  9. Unity3D专访——真正的面试

    本来想写一系列的,一半的攻击,现在面试的水.人之奸,用大哥的话说,要走新手是做螺丝钉和抹布用的.还有一半是对出出学校的或者是自废武功转3d的朋友们提供一个比較有价值的參考. 只是我时间实在仓促.没有保 ...

  10. 突破IP限制动态替换代理ip。

    须要导入的两个jar包 实现的javabean <span style="font-size:18px;">package com.jx.po; public clas ...