算法Day1(递归与分治)

汉诺塔递归算法实现

1.报错: [Error] a function-definition is not allowed here before ‘{’ token
原因:不能在一个函数里面再定义函数,但是我在main()函数中进行了要使用的函数的定义。

2.报错:[Error] lvalue required as left operand of assignment
原因:赋值语句的左边应该是变量,不能是表达式。
错误代码:

#include <iostream>
using namespace std;

int hannuota(int k);	//函数声明
int main(){
	int n;
	cin>>n;
	cout<<hannuota(n);
	return 0;
}
int hannuota(int k)
	{
		int m;
		hannuota(1)=1;
			m=2*hannuota(k-1)+1;
		return m;
	}

hannuota(1)=1;这样直接赋值时不可以的,应该改为:

int hannuota(int k)
	{
		int m;
		if(k==1)
			m=1;
		else
			m=2*hannuota(k-1)+1;
		return m;
	}
分治法求最大值

收获:
1.函数名与变量名最好不要重名。
2.函数形参表中有数组时的写法。
3.不定数组元素个数的数组的输入(键入到‘\n’时停止输入),注意用getchar()!=“\n”会报错,要用’\n’。
代码:

#include <iostream>
using namespace std;
int  find_max(int l,int r,int a[]);//数组作为形参时的写法
int main(){
	int a[100],i=1;
	while(getchar()!='\n'){
			cin>>a[i];
			i++;
	}
	cout<<find_max(1,i-1,a);//数组作为实参被调用时的用法
	return 0;
}

int  find_max(int l,int r,int a[]){ 
	int max,middle;
	if(l==r)
		max=a[l];
	else if (r==l+1){
		if(a[r]>a[l])
			max=a[r];
		else
			max=a[l];
	}
	else{
		if((l+r)%2==0)
			middle=(l+r)/2;
		else
			middle=(l+r+1)/2;
		if(find_max(l,middle,a)>find_max(middle,r,a))
			max=find_max(l,middle,a);
		else
			max=find_max(middle,r,a);
	}
	return max;	
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值