poj 1923 dp(Fourier's Lines)

本文深入分析了如何利用动态规划技术解决给定n条直线交于m个点时,最多能将平面分割成多少部分的问题。通过详细解释算法思路、代码实现以及边界条件判断,提供了求解此类几何问题的有效策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题意:给定两个正整数n和m,问n条直线交于m个点最多能把平面分成多少部分。要求不会多于两条直线交于一点。

思路:dp。知道是dp可是自己还是在一个地方卡住了,忍不住搜了题解发现也比较好理解。

#include <cstdio>
#include <cstring>
int dp[105][10005];
int n,m,c=1;
int out(int y,int x){
    return y<0 || (y>x*(x-1)/2) || (y>0&&y<x-1);
}
int test(int x,int y){
    int i;
    if(out(y,x))
        return 0;
    if(!y)
        return 1;
    if(dp[x][y] != -1)
        return dp[x][y];
    for(i = 1;i<=x;i++){
        dp[x][y] = test(x-i, y-i*(x-i));
        if(dp[x][y])
            return 1;
    }
    return 0;
}
int main(){
    memset(dp, -1, sizeof(dp));
    while(scanf("%d %d",&n,&m) && (n+m)){
        printf("Case %d: %d ",c++,n);
        if(test(n,m))
            printf("lines with exactly %d crossings can cut the plane into %d pieces at most.\n",m,n+m+1);
        else
            printf("lines cannot make exactly %d crossings.\n",m);
    }
    return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值