码迷,mamicode.com
首页 > 移动开发 > 详细

计蒜之道 初赛 第三场--腾讯手机地图

时间:2015-07-19 15:04:49      阅读:188      评论:0      收藏:0      [点我收藏+]

标签:计蒜客   计蒜之道   腾讯手机地图   

题目大意是:

在坐标系里给你n个扇形的半径、起始,结束度数,计算扇形覆盖的面积。

如图:

技术分享


(因为现在无法提交了,所以无法验证代码,若有错的地方请指正)

这题首先要做的是对边的度数排序,不过是对所有度数排序,最开始想的时候只对扇形开始边的那个度数排序,写了半天一堆if else,后来突然想到了用所有边的度数排序。


首先需要对输进去每每条边度数进行处理,我用的是这个结构体

struct DU
{
	int du;//度数
	int r;//当前度数所对应的半径
	bool if_end;//是否为扇形的结束边
	int num;//扇形编号
}a[MAX];


进行面积计算首先对a[]进行排序,接下来需要用到一些变量:

一个set集合,记录扇形的半径;

一个标记变量R,记录当前已有半径中最大的那个;

记录起始,结束边的度数变量start,end;

面积s;

struct SET_R
{
	int r;//半径
	int num;//半径对应的扇形
	 bool operator < (const dd &a) const
     {
		 return du<=a.du;
     }
};
set<SET_R> set_r;// 记录扇形的半径
set<SET_R>::iterator it;
int R;// 当前已有半径中最大的那个,即set_r.begin()
int start,end;// 起始,结束边的度数变量start,end
int s;
SET_R temp;


下面循环计算面积

从小到大扫描边的度数:

1. set_r 不为空:

当前边半径r>=R,更新end,计算从start到end的面积,更新start;

  否则,更新start;

2. 更新set_r,遇到起始边把半径加入set_r,更新R;遇到结束边把此边对应半径从set_r删除,更新R


for(i=0;i<n;i++)
{
	if(set_r.empty()==false )
	{
		if(R<=a[i].r )//如果当前边的半径r>=R
		{
			end=a[i].du;//更新end
			s+=(end-start)*R*R*PI/360;//计算面积,注意需要对减法处理一下
			start=end;//更新start
		}
	}
	else
	{
		start=a[i].du;
	}

	//更新set_r
	temp.r=a[i].r;
	temp.num=a[i],num;
	if(a[i].if_end==false)
	{
		set_r.insert(temp);
	}
	else
	{
		set_r.erase(temp);
	}
	//更新R
	if(set_r.empty()==false)
	{
		it=set_r.begin();
		R=(*it).r;
	}
}

下面就以实际的例子来说明吧,这个例子包含了所有可能的情况。

比如给的扇形是:

10 10 120

25 20 40

25 80 100

20 30 90

5 70 150

如图

技术分享


对这组数进行整理后得到如下数组 (红色为结束边)

 

0

1

2

3

4

5

6

7

8

9

度数

10

20

30

40

70

80

90

100

120

150

半径

10

25

20

25

5

25

20

25

10

5

 


扫描[0]

1

 

0

1

2

3

4

5

6

7

8

9

度数

10

20

30

40

70

80

90

100

120

150

半径

10

25

20

25

5

25

20

25

10

5

 

因为Set_r为空

所以start=a[i].du

2

更新set_r

 

 

 

 

 

 

 

 

 

 

 

set_r

10

 

 

 

 

 

 

 

 

 

 

R=10;

 


扫描[1]

1

 

0

1

2

3

4

5

6

7

8

9

度数

10

20

30

40

70

80

90

100

120

150

半径

10

25

20

25

5

25

20

25

10

5

 

因为R<= a[i].r && set_r不空

所以end=a[i].du

S+=(end-start)*R*R*PI/360; //计算面积,注意需要对减法处理一下

Start=a[i].du

 

2

更新set_r

 

 

 

 

 

 

 

 

 

 

 

set_r

25

10

 

 

 

 

 

 

 

 

 

R=25;

 

计算得到蓝色部分面积

技术分享




扫描[2]

1

 

0

1

2

3

4

5

6

7

8

9

度数

10

20

30

40

70

80

90

100

120

150

半径

10

25

20

25

5

25

20

25

10

5

 

因为R>a[i].r ,跳过

 

2

更新set_r

 

 

 

 

 

 

 

 

 

 

 

set_r

25

20

10

 

 

 

 

 

 

 

 

R=25;

 

扫描[3]

1

 

0

1

2

3

4

5

6

7

8

9

度数

10

20

30

40

70

80

90

100

120

150

半径

10

25

20

25

5

25

20

25

10

5

 

因为R<= a[i].r && set_r不空

 

所以end=a[i].du

S+=(end-start)*R*R*PI/360; //计算面积,注意需要对减法处理一下

Start=end

 

2

更新set_r

 

 

 

 

 

 

 

 

 

 

 

set_r

20

10

 

 

 

 

 

 

 

 

 

R=20;

 

计算得到蓝色部分面积


技术分享

扫描[4]

1

 

0

1

2

3

4

5

6

7

8

9

度数

10

20

30

40

70

80

90

100

120

150

半径

10

25

20

25

5

25

20

25

10

5

 

因为R> a[i].r ,跳过

 

2

更新set_r

 

 

 

 

 

 

 

 

 

 

 

set_r

20

10

5

 

 

 

 

 

 

 

 

R=20

 

 

扫描[5]

1

 

0

1

2

3

4

5

6

7

8

9

度数

10

20

30

40

70

80

90

100

120

150

半径

10

25

20

25

5

25

20

25

10

5

 

因为R<= a[i].r && set_r不空

 

所以end=a[i].du

S+=(end-start)*R*R*PI/360; //计算面积,注意需要对减法处理一下

Start=end

 

 

2

更新set_r

 

 

 

 

 

 

 

 

 

 

 

set_r

25

20

10

5

 

 

 

 

 

 

 

R=25;

 

计算得到蓝色部分面积

技术分享


扫描[6]

1

 

0

1

2

3

4

5

6

7

8

9

度数

10

20

30

40

70

80

90

100

120

150

半径

10

25

20

25

5

25

20

25

10

5

 

因为R>a[i].r ,跳过

 

 

 

2

更新set_r

 

 

 

 

 

 

 

 

 

 

 

set_r

25

10

5

 

 

 

 

 

 

 

 

 

扫描[7]

1

 

0

1

2

3

4

5

6

7

8

9

度数

10

20

30

40

70

80

90

100

120

150

半径

10

25

20

25

5

25

20

25

10

5

 

因为R<= a[i].r && set_r不空

 

所以end=a[i].du

S+=(end-start)*R*R*PI/360; //计算面积,注意需要对减法处理一下

Start=end

 

 

2

更新set_r

 

 

 

 

 

 

 

 

 

 

 

set_r

10

5

 

 

 

 

 

 

 

 

               

R=10;

 

计算得到蓝色部分面积

技术分享


扫描[8]

1

 

0

1

2

3

4

5

6

7

8

9

度数

10

20

30

40

70

80

90

100

120

150

半径

10

25

20

25

5

25

20

25

10

5

 

因为R<= a[i].r && set_r不空

 

所以end=a[i].du

S+=(end-start)*R*R*PI/360; //计算面积,注意需要对减法处理一下

Start=end

 

 

2

更新set_r

 

 

 

 

 

 

 

 

 

 

 

set_r

5

 

 

 

 

 

 

 

 

 

 

R=5;

 

计算得到蓝色部分面积

技术分享


扫描[9]

1

 

0

1

2

3

4

5

6

7

8

9

度数

10

20

30

40

70

80

90

100

120

150

半径

10

25

20

25

5

25

20

25

10

5

 

因为R<= a[i].r && set_r不空

 

所以end=a[i].du

S+=(end-start)*R*R*PI/360; //计算面积,注意需要对减法处理一下

Start=end

 

 

2

更新set_r

 

 

 

 

 

 

 

 

 

 

 

set_r

 

 

 

 

 

 

 

 

 

 

 

 

计算得到蓝色部分面积



技术分享








版权声明:本文为博主原创文章,未经博主允许不得转载。

计蒜之道 初赛 第三场--腾讯手机地图

标签:计蒜客   计蒜之道   腾讯手机地图   

原文地址:http://blog.csdn.net/u013011866/article/details/46954513

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!