您的位置:首页 > 编程语言 > C语言/C++

纯C语言:40磅砝码称重源码

2014-01-03 00:11 375 查看
#include<stdio.h>
int get(int weight,int i,int j,int k,int l)
{
	int p1,p2,p3,p4;
	for(p1=-1;p1<=1;p1++)
	{
		for(p2=-1;p2<=1;p2++)
		{
			for(p3=-1;p3<=1;p3++)
			{
				for(p4=-1;p4<=1;p4++)
				{
					if(i*p1+j*p2+k*p3+l*p4==weight)
						return 1;
				}
			}
		}
	}
	return 0;

}
void main()
{
	int i,j,k,l,weight;
	printf("40磅的砝码分解成四种不同重量的砝码,可有为以下的方案来实现可称出40磅内不同重量的物体:\n");
	for(i=1;i<10;i++)
	{
		for(j=i+1;j<20-i;j++)
		{
			for(k=j+1;k<30-i-k;k++)
			{
				for(l=k+1;l<=40-i-j-k;l++)
				{
					if(i+j+k+l==40)
					{
						for(weight=1;weight<=40;weight++)
						{
							if(!get(weight,i,j,k,l))
								break;
						}
						if(weight >40)
						   printf("%d  %d  %d  %d\n",i,j,k,l);
					}
				}
			}
		}
	}
}

#include<iostream.h>
int getweight(int i,int j,int k,int s,int w)
{
	int x1,x2,x3,x4;
	for(x1=-1;x1<=1;x1++)
       for(x2=-1;x2<=1;x2++)
		   for(x3=-1;x3<=1;x3++)
			   for(x4=-1;x4<=1;x4++)
				   if(x1*i+x2*j+x3*k+x4*s==w)
					   return 1;
	return 0;
}
int justify(int i,int j,int k,int s)
{
	int w;
	for(w=1;w<=40;w++)
	{
		if(!getweight(i,j,k,s,w))
			return 0;
	}
	return 1;
}
void pieces()
{
	int i,j,k,s;
	for(i=1;i<40;i++)
		for(j=i+1;j<40-i;j++)
			for(k=j+1;k<40-i-j;k++)
				for(s=k+1;s<=40-i-j-k;s++)
					if(i+j+k+s==40)
						if(justify(i,j,k,s))
							cout<<i<<" "<<j<<" "<<k<<" "<<s<<endl;
}
void main()
{
	pieces();
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: