森森最近想让自己的朋友圈熠熠生辉,所以他决定自己写个美化照片的软件,并起名为森森美图。众所周知,在合照中美化自己的面部而不美化合照者的面部是让自己占据朋友圈高点的绝好方法,因此森森美图里当然得有这个功能。 这个功能的第一步是将自己的面部选中。森森首先计算出了一个图像中所有像素点与周围点的相似程度的分数,分数越低表示某个像素点越“像”一个轮廓边缘上的点。 森森认为,任意连续像素点的得分之和越低,表示它们组成的曲线和轮廓边缘的重合程度越高。为了选择出一个完整的面部,森森决定让用户选择面部上的两个像素点A和B,则连接这两个点的直线就将图像分为两部分,然后在这两部分中分别寻找一条从A到B且与轮廓重合程度最高的曲线,就可以拼出用户的面部了。 然而森森计算出来得分矩阵后,突然发现自己不知道怎么找到这两条曲线了,你能帮森森当上朋友圈的小王子吗?

为了解题方便,我们做出以下补充说明:

  • 图像的左上角是坐标原点(0,0),我们假设所有像素按矩阵格式排列,其坐标均为非负整数(即横轴向右为正,纵轴向下为正)。
  • 忽略正好位于连接A和B的直线(注意不是线段)上的像素点,即不认为这部分像素点在任何一个划分部分上,因此曲线也不能经过这部分像素点。
  • 曲线是八连通的(即任一像素点可与其周围的8个像素连通),但为了计算准确,某像素连接对角相邻的斜向像素时,得分额外增加两个像素分数和的√​2​​​倍减一。例如样例中,经过坐标为(3,1)和(4,2)的两个像素点的曲线,其得分应该是这两个像素点的分数和(2+2),再加上额外的(2+2)乘以(√​2​​​−1),即约为5.66。

输入格式:

输入在第一行给出两个正整数N和M(5),表示像素得分矩阵的行数和列数。

接下来N行,每行M个不大于1000的非负整数,即为像素点的分值。

最后一行给出用户选择的起始和结束像素点的坐标(和(。4个整数用空格分隔。

输出格式:

在一行中输出划分图片后找到的轮廓曲线的得分和,保留小数点后两位。注意起点和终点的得分不要重复计算。

输入样例:

6 6
9 0 1 9 9 9
9 9 1 2 2 9
9 9 2 0 2 9
9 9 1 1 2 9
9 9 3 3 1 1
9 9 9 9 9 9
2 1 5 4

输出样例:

27.04

用深搜果然超时了,所以得用广搜了,但并不是每个点都入队列一遍就可以,需要维护一个数组,用来记录从起点(sx,sy)到这个点的最小值,不断更新,如果更新了就入队,否则不入,直到队列为空,
返回终点(ex,ey)的最小值,另外是开头输入起点和终点,给出的是坐标,根数组下标其实是相反的,这个是后来才发现的,判断一个点是否和起点和终点连线共线,可以用向量叉乘积判断,根据右手定则吧应该是。
可以先打表存好,用一个flag与之对应,要bfs两次,找连线的两层吗,通过改变flag的值,判断哪些点是属于正确的一侧。 代码:
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <queue>
#include <cmath>
#define inf 0x3f3f3f3f
using namespace std;
typedef pair<int,int> pa;
typedef pair<pair<int,int>,double> paa;
const double r = sqrt() - ;
int n,m;
int sx,sy,ex,ey;
double mp[][];
int flag;
int dir[][] = {,,,,,-,-,,-,-,,-,-,,,};
int cc[][];
double rr[] = {,,,,r,r,r,r};
int check(int x,int y) {
int d = (sx - x) * (ey - y) - (ex - x) * (sy - y);
if(d) return d / abs(d);
return ;
}
double bfs() {
bool vis[][] = {false};
double msum[][];
for(int i = ;i < n;i ++) {
for(int j = ;j < m;j ++) {
msum[i][j] = inf;
}
}
msum[sx][sy] = mp[sx][sy];
queue<paa> q;
q.push(paa(pa(sx,sy),mp[sx][sy]));
while(!q.empty()) {
int x = q.front().first.first;
int y = q.front().first.second;
double sum = q.front().second;
q.pop();
for(int i = ;i < ;i ++) {
int tx = x + dir[i][];
int ty = y + dir[i][];
if(tx < || ty < || tx >= n || ty >= m || cc[tx][ty] != flag) continue;
double tsum = sum + mp[tx][ty] + rr[i] * (mp[x][y] + mp[tx][ty]);
if(tsum < msum[tx][ty]) {
q.push(paa(pa(tx,ty),msum[tx][ty] = tsum));
}
}
}
return msum[ex][ey];
}
int main() {
scanf("%d%d",&n,&m);
for(int i = ;i < n;i ++) {
for(int j = ;j < m;j ++) {
scanf("%lf",&mp[i][j]);
}
}
scanf("%d%d%d%d",&sy,&sx,&ey,&ex);
for(int i = ;i < n;i ++) {
for(int j = ;j < m;j ++) {
cc[i][j] = check(i,j);
}
}
double ans = - mp[sx][sy] - mp[ex][ey];
cc[sx][sy] = cc[ex][ey] = flag = ;
ans += bfs();
cc[sx][sy] = cc[ex][ey] = flag = -;
ans += bfs();
printf("%.2f",ans);
}

重温:

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <queue>
#include <cmath>
#define inf 0x3f3f3f3f
using namespace std;
const double r = sqrt() - ;
int flag;
int n,m,sx,sy,ex,ey;
int dir[][] = {,,,,,-,-,,,,-,-,-,,,-};
double rr[] = {,,,,r,r,r,r};
double mp[][];
double mpm[][];
struct po {
int x,y;
double sum;
po(){}
po(int x,int y,double sum) {
this -> x = x;
this -> y = y;
this -> sum = sum;
}
}temp;
int check(int x,int y) {
if(x == ex && y == ey) return flag;
int d = (sx - x) * (ey - y) - (sy - y) * (ex - x);
if(d) return d / abs(d);
return ;
}
double bfs() {
queue<po> q;
q.push(po(sx,sy,mp[sx][sy]));
mpm[sx][sy] = mp[sx][sy];
mpm[ex][ey] = inf;
while(!q.empty()) {
temp = q.front();
q.pop();
for(int i = ;i < ;i ++) {
int tx = temp.x + dir[i][];
int ty = temp.y + dir[i][];
if(tx < || ty < || tx >= n || ty >= m || check(tx,ty) != flag) continue;
double sum = temp.sum + mp[tx][ty] + rr[i] * (mp[tx][ty] + mp[temp.x][temp.y]);
if(sum < mpm[tx][ty]) {
q.push(po(tx,ty,sum));
mpm[tx][ty] = sum;
}
}
}
return mpm[ex][ey];
}
int main() {
cin>>n>>m;
for(int i = ;i < n;i ++) {
for(int j = ;j < m;j ++) {
cin>>mp[i][j];
mpm[i][j] = inf;
}
}
cin>>sy>>sx>>ey>>ex;
flag = -;
double ans = -mp[sx][sy] - mp[ex][ey] + bfs();
flag = ;
ans += bfs();
printf("%.2f",ans);
}

L3-018 森森美图 (30 分)的更多相关文章

  1. L3-2 森森快递 (30 分)(贪心+线段树/分块)

    题目链接:https://pintia.cn/problem-sets/1108203702759940096/problems/1108204121661857798 题目大意: 森森开了一家快递公 ...

  2. L3-017 森森快递 (30 分)

    森森开了一家快递公司,叫森森快递.因为公司刚刚开张,所以业务路线很简单,可以认为是一条直线上的N个城市,这些城市从左到右依次从0到(编号.由于道路限制,第i号城市(,)与第(号城市中间往返的运输货物重 ...

  3. 【Python3网络爬虫开发实战】6.4-分析Ajax爬取今日头条街拍美图【华为云技术分享】

    [摘要] 本节中,我们以今日头条为例来尝试通过分析Ajax请求来抓取网页数据的方法.这次要抓取的目标是今日头条的街拍美图,抓取完成之后,将每组图片分文件夹下载到本地并保存下来. 1. 准备工作 在本节 ...

  4. 【Python3网络爬虫开发实战】 分析Ajax爬取今日头条街拍美图

    前言本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:haoxuan10 本节中,我们以今日头条为例来尝试通过分析Ajax请求 ...

  5. 转:【Python3网络爬虫开发实战】6.4-分析Ajax爬取今日头条街拍美图

    [摘要] 本节中,我们以今日头条为例来尝试通过分析Ajax请求来抓取网页数据的方法.这次要抓取的目标是今日头条的街拍美图,抓取完成之后,将每组图片分文件夹下载到本地并保存下来. 1. 准备工作 在本节 ...

  6. 【30分钟学完】canvas动画|游戏基础(extra1-1):美图我也行

    前言 本文是接续系列教程的extra1,主要是介绍颜色系统在canvas中的应用. 本来是与extra1一起成文的,因为segmentfault莫名其妙的字数限制bug只能分割放送了. canvas操 ...

  7. iOS开发系列--打造自己的“美图秀秀”

    --绘图与滤镜全面解析 概述 在iOS中可以很容易的开发出绚丽的界面效果,一方面得益于成功系统的设计,另一方面得益于它强大的开发框架.今天我们将围绕iOS中两大图形.图像绘图框架进行介绍:Quartz ...

  8. iOS开发系列--打造自己的“美图秀秀”

    概述 在iOS中可以很容易的开发出绚丽的界面效果,一方面得益于成功系统的设计,另一方面得益于它强大的开发框架.今天我们将围绕iOS中两大图形.图像绘图框架进行介绍:Quartz 2D绘制2D图形和Co ...

  9. 美图美妆由Try Try接手运营

    美图又把一个拖累营收的业务转让出去了. 美图的电商业务——美图美妆应用在向用户发布终止运营的公告后,宣布把业务交给了寺库旗下公司 Try Try 运营.Try Try 接手了美图美妆的所有管理运营权, ...

随机推荐

  1. PHP消息队列之Beanstalk

    Beanstalk,一个高性能.轻量级的分布式内存队列

  2. Hibernate入门第二课 Hibernate Tools for Eclipse Plugins安装

    Hibernate入门第二课 Hibernate Tools for Eclipse Plugins安装 你们可以直接去,http://blog.csdn.net/wei_chong_chong/ar ...

  3. Ubuntu 14.04 的 VNC Server

    首先,如果是Desktop 版本的 Ubuntu,不需要另外安装vnc server. 网上也不知怎么搞的,一堆奇怪的方法,要安装TightVNCServer,然后一堆sb设置 然后,主要有两个配置 ...

  4. EF学习-获取实体框架01

    实体框架由 EF 设计器(包含在 Visual Studio 中)和 EF Runtime(在 NuGet 上提供)组成. EF 设计器包含在 Visual Studio 中 最新版本的实体框架设计器 ...

  5. hdu 6396 Swordsman (技巧)

    大意: n个怪, m种能力值, 当自己所有能力值不低于某只怪时可以杀死它, 并获得它的所有能力, 求最大杀几只 将每只怪拆成$m$个, 排下序贪心即可, 复杂度$O(nm)$, 原题极其卡时间, 我的 ...

  6. FastDFS install - 2

    storage install nginx 1. update dependency package yum -y install pcre-devel openssl openssl-devel g ...

  7. hdu多校2C

    题意:找多条路径覆盖所有的边,求最小路径数,要求输出路径 题解:新建一个点n+1,所有奇点向它连边,然后跑欧拉回路,最后把新加的边删去,一段连续的边就是一条路径 = =但是由于太久没写欧拉回路以及之前 ...

  8. python-day8-赋值

    # x=10 #链式赋值# a=b=c=d=e=f=10# print(a,b,c,d,e,f) #增量赋值 # x=10# y='a'# temp=x# x=y# y=temp# print(x,y ...

  9. POJ-3009 Curling 2.0 (DFS)

    Description On Planet MM-21, after their Olympic games this year, curling is getting popular. But th ...

  10. 使用UTL_SMTP发送中文邮件及使用UTL_TCP从附件服务器获取中文附件

    先上最重要的干货 发送邮件正文及主题的时候一定要使用convert重新编码 主题: utl_smtp.write_raw_data(l_mail_conn, utl_raw.cast_to_raw(c ...