POJ 1011 Sticks

POJ 1011 Sticks

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

DFS

题意是让你把这些木棍组合成长度相等的一些木棍。要求长度最短。

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
int a[65],n,sum,ans;
bool v[65],ok;
bool cmpa(int a,int b)
{
    return a>b;
}
bool dfs(int num,int need,int total)
{
    int i;
    if(need==0)
    {
        if(total==sum/ans-2)return 1;
        for(i=0;v[i];i++);
        v[i]=1;
        if(dfs(i+1,ans-a[i],total+1))return 1;
        v[i]=0;
        return 0;
    }
    else
    {
        if(num>=n-1)return 0;
        for(i=num;i<n;i++)
        {
            if(a[i]==a[i-1]&&!v[i-1])
            continue;
            if(!v[i]&&a[i]<=need)
            {
                v[i]=1;
                if(dfs(i,need-a[i],total))return 1;
                v[i]=0;
            }
        }
        return 0;
    }
}
int main()
{
    while(scanf("%d",&n),n)
    {
        sum=ans=0;
        for(int i=0;i<n;i++)
        scanf("%d",&a[i]),sum+=a[i];
        sort(a,a+n,cmpa);
        memset(v,0,sizeof(v));
        ok=0;
        for(ans=a[0];ans<=sum/2;ans++)
        {
            if(sum%ans==0)
            {
                v[0]=1;
                if(dfs(0,ans-a[0],0))
                {printf("%d\n",ans);ok=1;break;}
            }
        }
        if(!ok)
        printf("%d\n",sum);
    }
    return 0;
}

还有更强大的剪枝版本号的:

#include<cstdio>
#include<cstring>
#include<cstring>
#define MAX 64
int s[MAX],vis[MAX],n,len,sum;
void input()
{   int i,j,temp;
    sum = 0;
       for(i=0;i<n;i++)
         {
            scanf("%d ",&s[i]);
            sum+=s[i];
         }
      for(i=1;i<n;i++)
       for(j=0;j<n-i;j++)
       {
           if(s[j]<s[j+1])
          {
           temp = s[j];
           s[j] = s[j+1];
           s[j+1] = temp;
          }
       }
}
bool dfs(int now_len,int i,int count)
{
    if((count+1)*len==sum)
    {
        return true;
    }
    for(int k= i;k<n;k++)
    {
       if(vis[k]) continue;
       if(k&&!vis[k-1]&&s[k]==s[k-1]) continue;
       if(s[k]+now_len>len) continue;
       if(now_len+s[k]==len)
       {
           vis[k]=1;
           bool result = dfs(0,0,count+1);
           vis[k]=0; 
           return result;
       }
       else if(now_len==0)
       {
           vis[k]=1;
           bool result = dfs(s[k],k+1,count);
           vis[k]= 0;
           return result;
       }
       else if(now_len+s[k]<len)
       {
           vis[k] = 1;
           bool result = dfs(s[k]+now_len,k+1,count);
           vis[k] = 0;
           if(result)
           return true;
       }
    }
    return false;
}
int main()
{
    while(scanf("%d",&n),n)
    {
       input();
       for(len=s[0];len<=sum;len++)
       {
           if(sum%len) continue;
           memset(vis,0,sizeof(vis));
           if(dfs(0,0,0))
           break;
       }
       printf("%d\n",len);
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118378.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 微机原理与接口技术重要的知识点总结_微机原理与接口技术戴胜华

    微机原理与接口技术重要的知识点总结_微机原理与接口技术戴胜华概述8086有16位寄存器和16位外部数据总线,具有20位地址总线,可寻址1MB地址空间80286提供了24位基地址Intel80386处理器是IA-32结构系列中的第一个32位处理器。该处理器有32位地址总线,能支持多至4GB的物理存储器,把分页引进了IA-32结构,并行操作,分页就是一种保护模式80486在IA-32处理器的芯片中引入了缓存,也是第一次把x87FPU(浮点处理…

    2022年10月2日
    3
  • .py和.ipynb的小知识

    .py和.ipynb的小知识目录1.相同点2.区别3.转换4.类比1.相同点用Python语言编写的源代码文件,其文件后缀是“.py”或“.ipynb”。用Python语言编写的源代码文件,其文件后缀是“.py”或“.ipynb”。2.区别.py:".py"文件是标准的Python源代码文件,通常情况下,使用“.py”的python源代码文件。可以用Spyder编辑并运行.py文件。也可…

    2025年8月10日
    2
  • navicat 15激活码(破解版激活)

    navicat 15激活码(破解版激活),https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月16日
    45
  • MDK 生成BIN文件 最简单方式「建议收藏」

    MDK 生成BIN文件 最简单方式「建议收藏」如图中所示,一行命令就可以了。fromelf.exe–bin-o..\Output\@p.bin..\Output\@p.axf

    2022年10月20日
    2
  • 用ajax写注册页面_jquery的ajax请求写法

    用ajax写注册页面_jquery的ajax请求写法<!DOCTYPEhtml><htmllang=”zh-CN”xmlns:th=”http://www.thymeleaf.org”><head><metacharset=”utf-8″/><title>XXXX</title><metaname=”viewport”co…

    2022年9月27日
    2
  • 机械制图圆弧与圆弧连接画法_机械制图中圆角的画法

    机械制图圆弧与圆弧连接画法_机械制图中圆角的画法18圆弧连接的画法绘图时,经常要用已知半径的圆弧,但圆心要在作图中确定,这样的圆弧,称为连接圆弧。连接圆弧需要光滑连接已知直线或圆弧,光滑连接也就是要在连接点处相切。为了保证相切,必须准确地作出连接圆弧的圆心和切点。一、用已知半径为R的圆弧连接两条已知直线用半径为R的连接弧连接两已知直线的作图过程如图所示,其步骤为:1、求连接弧的圆心:作与两已知直线分别相距为R的平行线,交点O即为连接圆弧圆心;…

    2022年9月15日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号