2019-05-22

2050折线分割平面:http://acm.hdu.edu.cn/showproblem.php?pid=2050


第一次思路:我直接画了三条折线的图,如下图所示,画出三条折线最大能分割出14条线(错误的!!!)。我通过三个图,找到了一个错误的规律:

n=1时,封闭区域为0,开放区域为2;

n=2时,封闭区域为3,开放区域为4;

n=3时,封闭区域为8,开放区域为6;

为了验证封闭区域是否为n*n-1,开放区域为n*3,我画出了,四条折线的图,居然奇迹般的验证成功了。于是写出了如下的代码:

#include

int main()

{

   int m,n,sum;

   scanf("%d",&m);

   while(m--)

    {

      scanf("%d",&n);

      sum=0;

      sum=n*n-1+n*2;

      printf("%d\n",sum);

    }

    return 0;

}

这时候在oj上面提交,连续提交了三次都没成功。我感觉应该是最大切割平面的数量上出现了错误。

查询百度之后得出最大数量是16,但是我在草稿纸上面画了挺多种方案,就是没有一种是16的,这让我很头疼,看了前面几周同学发的笔记和一些博客。发现这是一道递推的题目,下面整理了一下:

1、先看看增加直线的情况:


不添加直线时,只有 1 个面;添加一条直线时,有 2 个面;添加两条直线时,有 4 个面;再往后添加直线时,为使分隔面尽可能的多,则第 n 条直线需与前 n - 1 条直线相交且不存在三线或三线以上交于一点的情况。这样的话,在平面中,增加第 n 条直线就会增加 n - 1 个交点。也不难发现,平面中增加 i 个点就会增加 i + 1 个面。所以 n 条直线分割平面最大数是1 + 1 + 2 + 3 + ... + n = (n2 + n + 2) / 2。

2、再看看增加平行线的情况:


一组平行线都不添加时,只有 1 个面;添加一组平行线时,有 3 个面;添加两组平行线时,有 9 个面;再往后添加平行线时,和上述添加直线情况类似。当第 n 次添加平行线时,前面已经有 2 * ( n - 1) 条直线了,所以第 n 组平行线,即 2n - 1 条和第 2n 条直线添加进去的时候,各增加了 2 * ( n - 1) 个点,也就是增加了 2 * ( n - 1) + 1 个面。所以第 n 次添加平行线增加的总面数是 2 * [ 2 * ( n - 1) + 1 ] = 4 * n - 2 .所以 n 组平行线分隔的总面数是 1 + ( 3 + 4 * 1 - 2 ) + ( 3+ 4 * 1 - 2 + 4 * 2 - 2 ) + …… + ( 3+ 4 * 1 - 2 + 4 * 2 - 2 + …… + 4 * n -2 ) = 2 * n2 + 1 。

3、最后是本题增加折线的情况:


平行线的一端相交就成了折线,相交后,有两个面就会合为一个面,所以 n 组平行线变成折线以后,就会减少 n 个面。所以本题 n 条折线就分割出 2 * n² - n + 1 个面。

正确代码为:

#include

int main()

{

   int m,n,sum;

   scanf("%d",&m);

   while(m--)

    {

      scanf("%d",&n);

      sum=0;

      sum=2*n*n-n+1;

      printf("%d\n",sum);

    }

   return 0;

}


心得:看似题目复杂,其实程序很简单,重要的是找出规律。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,561评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,218评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,162评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,470评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,550评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,806评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,951评论 3 407
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,712评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,166评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,510评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,643评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,306评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,930评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,745评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,983评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,351评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,509评论 2 348

推荐阅读更多精彩内容

  • 江柏文:5.22黄金最新走势分析及黄金操作建议策略 人生需要沉淀,宁静才能致远;人生需要反思,常回头看看,才能在品...
    江柏文阅读 137评论 0 0
  • 我相信友情可以通过各种方式、各种渠道、各种缘分得到。记得我和王主任的友谊是从“打”开始的。 那年,我刚接手一项新工...
    人在天涯是天涯阅读 406评论 2 5
  • 今天修整了一天,所有的事情都慢下来,心里没有很挂念的事,没有非做不可的事。昨天刚刚劝完朋友,生活从来没有容易一说。...
    罗洪绮阅读 113评论 0 1
  • 脚本优化 :https://wuzhiwei.net/unity_script_optimization/
    IamtheKingKing阅读 147评论 2 0
  • 2017实现目标的3大内功心法 当我们在2017年,针对我们企业和个人生命成长,有了战略目标的制定, 目标和结果很...
    添财尊佛阅读 272评论 0 0