欧拉项目第15题

此方法主要是对矩阵进行划分,此矩阵可以看做是一个21*21 格子矩阵,
然后对矩阵进行拆分 先从左上角划分出来一个11*11的矩阵,算出从左上角的方块出发,
到11行上和11列上各个方块的方法,由于对称,我们只需要求出从左上角到11行各个方块的方法,
然后将其储存在a数组里面!那个从坐标为(0,0)到坐标为(11,11)的方法先不用求,所以只有十个数,
然后再分别以这些终点为力一个矩阵的起点算,最后加上(11,11)到(21,21)的方法,就可以了!

但是此方法不推介,过于麻烦!而且效率低,只不过是一种思路! 

#include<stdio.h> 
__int64 count=0;//一个全局变量 
void diedai(int i,int j,int k,int l)//k,l分别表示行和列 
{

 	if(i==k||j==l)
	 {
	 	return ;
	 } 
	
	if(i==k-1&&j==l-1)
	{
		
		count++;
	//	printf("i=%d\n",count);
		return ;
	}
	diedai(i+1,j,k,l);
	diedai(i,j+1,k,l);
		

}

int main()
{
//	printf("字节为:%d",sizeof(long long int));
	__int64 center	=0;
	__int64 sum=0;
	__int64 a[10]={0},b[10]={0};
	for(int i=10,j=0;j<10;j++){
		count=0;
		diedai(0,0,i+1,j+1);		
		a[j]=count;
	//	printf("%d\n",a[j]);
		count=0;
		diedai(0,0,20-i,21-j);
		b[j]=count;
	
		
	
	} 
		for(int i=0;i<10;i++)
		{
			printf("a=%d   b=%d\n",a[i],b[i]);
			printf("a*b=%I64d\n",a[i]*b[i]);
			sum+=a[i]*b[i]*2;
			
		}
		count=0;
		diedai(0,0,11,11); 
		printf("count*count=%I64d\n",count*count);
		sum+=count*count;
	
		
	
	printf("方法的个数为:%I64d",sum);
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
欧拉伯努利试是一类经典的流体力学目,常用于讨论在流体中的连续性、动量守恒和能量守恒等方面的问。使用MATLAB可以方便地求解这类问。 要解决欧拉伯努利试,我们需要使用流体力学的基本原理,即连续性方程、动量守恒和能量守恒方程。我们可以利用MATLAB编写程序,将这些方程转化为数学模型,并求解相关的物理量。 对于欧拉伯努利试,我们常常需要求解的物理量包括流速、压力和液体高度等。在MATLAB中,我们可以利用流体力学的基本原理建立方程组,并使用数值求解方法计算出相关的物理量。 以一个简单的欧拉伯努利试为例,假设流体在一段管道中流动,已知管道的截面积、液体的初始速度和液体的高度等参数。我们可以利用连续性方程、动量守恒和能量守恒方程,通过MATLAB编写程序求解出管道中的流速、压力和液体的高度等参数。 在MATLAB中,我们可以使用数值求解方法(如Euler法、Runge-Kutta法)对欧拉伯努利试进行数值求解。同时,我们还可以利用MATLAB的可视化功能,将求解结果绘制成图形,更直观地展示出物理量的变化规律。 综上所述,欧拉伯努利试是一个典型的流体力学问,在MATLAB中可以方便地使用数值求解方法求解相关的物理量,并利用可视化功能展示求解结果。通过MATLAB的应用,我们可以更深入地理解流体力学的基本原理,同时也可以更直观地展示和分析物理量的变化情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值