zoukankan      html  css  js  c++  java
  • ACM2050

    问题描述

      平面上有n条折线,问这些折线最多能将平面分割成多少块?

    样例输入

    1

    2

    样例输出

    2

    7

    答案是: 

    2n ( 2n + 1 ) / 2 + 1 - 2n

    = 2 n^2  n + 1

    当第N次添加时,前面已经有2N-2条直线了,所以第N次添加时,第2N-1条直线和第2N条直线都各能增加2*n-1+1 个平面。

    所以第N次添加增加的面数是2[2(n-1) + 1] = 4n - 2 个。因此,总面数应该是

    1 + 4n(n+1)/2 - 2n = 2n2 + 1 

    如果把每次加进来的平行边让它们一头相交

    当第N次添加时,前面已经有2N-2条直线了,所以第N次添加时,第2N-1条直线和第2N条直线都各能增加2*n-1+1 个平面。

    所以第N次添加增加的面数是2[2(n-1) + 1] = 4n - 2 个。因此,总面数应该是

    1 + 4n(n+1)/2 - 2n = 2n2 + 1 

    如果把每次加进来的平行边让它们一头相交

    则平面13已经合为一个面,因此,每一组平行线相交后,就会较少一个面,

     在ACM2050前传中已经给出了直线的时平面数,而折线看成是两条直线,便可利用上一篇的公式了。

    当第N次添加时,前面已经有2N-2条直线了,所以第N次添加时,第2N-1条直线和第2N条直线都各能增加2*n-1+1 个平面。

    所以第N次添加增加的面数是2[2(n-1) + 1] = 4n - 2 个。因此,总面数应该是

    1 + 4n(n+1)/2 - 2n = 2n^2 + 1 

    如果把每次加进来的平行边让它们一头相交

    杭电acm2050 折线分割平面 - wang812689440 - panda的博客

    则平面13已经合为一个面,因此,每一组平行线相交后,就会较少一个面.

    #include<stdio.h>

    int main()

    {

    int T,n;

    scanf("%d",&T);

    while(T--&&scanf("%d",&n)!=EOF)

    printf("%d ",2*n*n-n+1);

    return 0;

    }

  • 相关阅读:
    jmeterxpath的用法
    Jmeter中Websocket协议支持包的使用
    http 错误代码汇总
    Jmeter正则表达和xpath
    SSH Secure Shell Client安装和使用
    SecureCRT安装步骤
    DataRow转化成对象
    vb.net 与 c# 的switch ... case ...的一个重要区别
    DataRow 转换成Entity实例
    Sqlserver查找数据库中含有某字段的所有表
  • 原文地址:https://www.cnblogs.com/orangebook/p/3148511.html
Copyright © 2011-2022 走看看