【递归学习笔记】小李做梦也想不到,这两天被递归吃的死死的

 

最近报的开课吧C语言代码(也许当时我就是卡在递归那个走楼梯那但是没有补漏直至今日还是找上门来了)

原题:折半查找

我们刚刚学习了折半查找,但是还没有自己来实践一下,这一节,你就需要自己实现一个折半查找的程序啦。

给定 N 个整数和 K 个待查找的整数 M1​,M2​,...,MK​。如果待查找的整数在给定的 N 个整数中,请输出待查找的整数是数组中第几个元素(从 1 开始计算,第一个元素计 1而不是 0);如果待查找的整数不在给定的 N个整数中,则输出 0

输入格式

测评机可能会反复运行程序,每次程序运行后,测评机输入包括三行。第一行输入两个整数 N(N∈[1,1e6])和 K(K∈[1,1e6]),分别表示给定的整数总个数和待查找的数的个数;第二行自小到大输入 N 个整数 Number_i(Number_i∈[1,1e6],其中i∈[1,N]),每两个整数之间用一个空格隔开;第三行输入 K 个整数 Number_j(Number_j∈[1,1e6],其中j∈[1,N]),每两个整数之间用一个空格隔开。

输出格式

输出为一行,包括 K 个部分,每个部分为题目描述中待查找的元素索引或 0,K 个部分之间用一个空格分隔。输出行尾不含多余空格。(这个课最狗就在这里 一直卡这个输入格式/*  3 */)

样例输入1

3 1
1 4 6
4

样例输出1

2

样例输入2

5 2
1 4 6 7 8
5 1

样例输出2

0 1

样例输入3

6 4
1 2 4 6 7 8 
9 1 5 2

样例输出3

0 1 0 2

这道题思路很简单,但是我呵呵呵想半天

虽然教程给了动画也很简便,但是落实到代码还是不太容易;

先给一串伪代码各位看官过目

 

这种憋了半天求出来的感觉!真爽~一开始主要错在我以为这个可以直接返回数字输出,然而还是需要加一个vet去判断。

上代码!!!!终于AC了 菜鸟小李要奖励自己看一部哈利波特(今天我已经不是麻瓜了,我也是知道9 3/4 的火车站站口在哪的人啦~)

#include <stdio.h>
#define N 1000010
int binfind(int x, int a[], int left, int right)
{
	while (left <= right) {
		int mid = left - (left - right) / 2;
		if (a[mid] == x) {
			return mid;
		}
		else if (x < a[mid]) {
			right = mid - 1;
		}
		else {
			left = mid + 1;
		}
	}
	return -1;
}
int main()
{
	int arr[N];
	int vet,num,n,k;
	scanf("%d %d",&n,&k);
	for(int i=0;i<n;i++)scanf("%d",&arr[i]);
	for(int j=0;j<k;j++){
		scanf("%d",&num);
		vet = binfind(num, arr, 0, n-1);
		if (vet != -1) {
			printf("%d", vet+1);
		}
		else printf("0");
		if(j!=k-1)printf(" ");
	}
	return 0;
}

(这里先留个空子,现在掌握的就是线性筛选(1~n),折半筛选法,另外需要补充的是埃式筛法+线性筛法(acwing上的课程叫这个名字,后面这两个就在质数筛那个笔记里重现吧!))

第二道题是蓝桥杯原题,然而我还是没有开始(2333淡定的复习自己的c语言,其他竟然除了正科作业全淡了,除了周六那场比赛)

下期预告:斐波那契考法总结

斐波那契数列+递归:

直接上图吧,懒得打字;

这道题乍一看,以为是斐波那契数列,其实不然,是升级版~

对C语言掌握还不是很熟练的同学可能会想到,直接用递归函数+代数。亲测到36就卡了(可能是我电脑的问题叭~)

这正是这道题巧妙之处了,然后有个聚聚教我可以边算边%10000,毕竟要的只是最后四位;

一开始我想的是肯定有什么规律啊(毕竟年前教小侄子奥数题就这个套路,然而我忽略了这是个大学生的比赛)

然后我就想到可以用字符串,但是这触及我知识盲区了,卡了好久嘤嘤嘤~

(顺便说一下,历史上第一个程序员是女性:阿达·洛芙莱斯,女程序员们节日快乐鸭~~~)

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值