博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
枚举超时
阅读量:5111 次
发布时间:2019-06-13

本文共 2245 字,大约阅读时间需要 7 分钟。

糖果问题枚举会导致超时的。。

#include<stdio.h>

float mabs(float a)
{
if(a<0)
a=-a;
return (a);
}
int max(int a[4])
{
int i,j,t;
for(i=0;i<3;i++)
{
if(a[i]>a[i+1])
{
j=a[i+1];a[i+1]=a[i];a[i]=j;
}

}

//printf("%d%d%d %d\n",a[0],a[1],a[2],a[3]);
t=a[3];
return (t);
}
int min(int a[4])
{
int i,j,t;
for(i=0;i<3;i++)
{
if(a[i]<a[i+1])
{
j=a[i+1];a[i+1]=a[i];a[i]=j;
}
}
t=a[3];
//printf("%d%d%d%d\n",a[0],a[1],a[2],a[3]);
return (t);
}
int main()
{
int i,j,m,n,a[4]={0};
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
if(n==0) printf("YES\n1\n1\n3\n3\n");
else if(n==1)
{
if(n%2==0) printf("YES\n%d\n%d\n%d\n",a[0],a[0]/2,a[0]*1.5);
else printf("YES\n%d\n%d\n%d\n",a[0]+1,(a[0]/2)+1,(a[0]/2)+1+a[0]);
}
else if(n==2)
{
float e=0,r,w;
int h=0,b[2]={0},f,i,j;
//printf("%d%d%d%d\n",a[0],a[1],a[2],a[3]);
for(i=1;i<=1000000;i++)
{
for(j=1;j<=1000000;j++)
{
a[2]=i;
a[3]=j;
for(f=0;f<2;f++)
{
b[f]=a[f];
}
//printf("%d%d%d\n",w,e,r);
//printf("%d%d%d%d\n",a[0],a[1],a[2],a[3]);
w=(a[0]+a[1]+a[2]+a[3])/4.0;
e=max(a)-min(a);
//printf("%d%d%d%d\n",a[0],a[1],a[2],a[3]);
r=(a[0]+a[1]+a[2]+a[3]-max(a)-min(a))/2.0;
//printf("%f %f %f\n",w,e,r);
if((mabs(w-e)<1e-6)&&(mabs(e-r)<1e-6))
{
printf("YES\n%d\n%d\n",i,j);
h++;
break;
}
for(f=0;f<2;f++)
{
a[f]=b[f];
}
}
if(h!=0) break;
}
if(h==0)
printf("NO");
}
else if(n==3)
{
float e=0;
float r,w;
int h=0,b[3]={0};
//printf("%d%d%d%d\n",a[0],a[1],a[2],a[3]);
for(i=1;i<=1000000;i++)
{
a[3]=i;
for(j=0;j<3;j++)
{
b[j]=a[j];
}
//printf("%d%d%d\n",w,e,r);
//printf("%d%d%d%d\n",a[0],a[1],a[2],a[3]);
w=(a[0]+a[1]+a[2]+a[3])/4.0;
e=max(a)-min(a);
//printf("%d%d%d%d\n",a[0],a[1],a[2],a[3]);
r=(a[0]+a[1]+a[2]+a[3]-max(a)-min(a))/2.0;
//printf("%f %f %f\n",w,e,r);
if(((w-e)<1e-6)&&((e-r)<1e-6))
{
printf("YES\n%d\n",i);
h++;
break;
}
for(j=0;j<3;j++)
{
a[j]=b[j];
}
}
if(h==0)
printf("NO");
}
else if(n==4)
{
float e=0;
float r,w;
//printf("%d%d%d\n",w,e,r);
//printf("%d%d%d%d\n",a[0],a[1],a[2],a[3]);
w=(a[0]+a[1]+a[2]+a[3])/4.0;
e=max(a)-min(a);
//printf()
//printf("%d%d%d%d\n",a[0],a[1],a[2],a[3]);
r=(a[0]+a[1]+a[2]+a[3]-max(a)-min(a))/2.0;
//printf("%f %f %f\n",w,e,r);
if(mabs((w-e)<1e-6)&&(mabs(e-r)<1e-6))
printf("YES");
else
printf("NO\n");
}
return 0;
}

转载于:https://www.cnblogs.com/linminxuan/p/4136122.html

你可能感兴趣的文章
(安卓)一般安卓开始界面 Loding 跳转 实例 ---亲测!
查看>>
Mysql 索引优化 - 1
查看>>
LeetCode(3) || Median of Two Sorted Arrays
查看>>
大话文本检测经典模型:EAST
查看>>
待整理
查看>>
一次动态sql查询订单数据的设计
查看>>
C# 类(10) 抽象类.
查看>>
Vue_(组件通讯)子组件向父组件传值
查看>>
jvm参数
查看>>
我对前端MVC的理解
查看>>
Silverlight实用窍门系列:19.Silverlight调用webservice上传多个文件【附带源码实例】...
查看>>
2016.3.31考试心得
查看>>
mmap和MappedByteBuffer
查看>>
Linux的基本操作
查看>>
转-求解最大连续子数组的算法
查看>>
对数器的使用
查看>>
【ASP.NET】演绎GridView基本操作事件
查看>>
ubuntu无法解析主机错误与解决的方法
查看>>
尚学堂Java面试题整理
查看>>
MySQL表的四种分区类型
查看>>