从一组有顺序的数字中依次查找一个数

在一个数组中找一个数字,并且返回下标

#include <stdio.h>
#include <stdlib.h>

void  FindNumber(int arr[], int size, int toFind){
	for (int i = 0; i < size;i++){
		if (arr[i] == toFind  ){
			printf("找到了,下标是: %d\n",i);
		}
	}
}
int main(){
	int arr[] = { 9, 5, 2, 7 };
	int toFind = 2;
	int size = sizeof(arr) / sizeof(arr[0]);// 数组的大小
	FindNumber(arr, size, toFind);
	system("pause");
	return 0;
}

运行结果:
在这里插入图片描述
拓展1:写一个函数,在一个有序数组中找一个数字,找到返回下标,没找到返回没找到.(二分查找)

#include <stdio.h>
#include <stdlib.h>

int main(){
	int arr[] = { 1,2,3,4,5,6,7,8,9};
	int toFind = 10;
	//int toFind = 3;
	int left=0;
	int right = sizeof(arr) / sizeof(arr[0])-1;// 数组的大小
	//[left,right]  数组下标大小的区间范围
	int mid;
	while (left <= right){
		mid = (left + right) / 2;
		if (arr[mid] > toFind){
			right = mid - 1;
		}
		else if (arr[mid] < toFind){
			left = mid + 1;
		}
		else {
			printf("找到了,下标是: %d\n", mid);
			break;
		}
	}
	if (left > right){
		printf("没找到\n");
	}
	system("pause");
	return 0;
}

运行结果:
toFind=10时
在这里插入图片描述
toFind=3时
在这里插入图片描述
拓展2.写一个函数,在一个有序数组中找一个数字,找到返回下标.找不到返回-1.(二分查找)

#include<stdio.h>
int FindNumber(int arr1[],int size,int Tofind ) {
	int left = 0;
	int right = size - 1;
	int i;
	int mid;
	while (left<=right){
		mid = (right + left) / 2;
		if (arr1[mid] > Tofind){
			right = mid - 1;
		}
		else if (arr1[mid] < Tofind){
			left = mid + 1;
		}
		else {
			return mid;
		}
	}
	return -1;
}
int main(){
	int mid;
	int arr[8] = { 1, 2, 3, 4, 5, 6, 7, 8 };
	int ret = FindNumber(arr, 8, 8);
	printf("%d\n", ret);
	system("pause");
	return 0;
}

重点:在传参的过程中,应该在函数的外部算出元素的个数,然会在以参数的形式传给函数

运行结果:
在这里插入图片描述

没有找到的情况:
在这里插入图片描述
关于一维数组的总结:
1.数组的创建,[]中要给一个常量,不能使用变量。
2.数组的初始化,初始化和赋值不相同
int arr1[] = {1,2,3,4}
int arr2[4] = {1,1,2,3}
char arr3[] = {‘a’,‘b’,‘v’,‘c’}
char arr4[] = “abnc”
3.数组的使用都是通过下标来访问的,下标从0开始
4.数组的大小可以通过计算得到 sizeof ,strlen

字符串(\0结尾)的大小用strlen函数求解
字符数组的大小用sizeof来求解
5.数组作为函数参数的时候,不会把整个数组传递过去,数组作为函数参数时,不会把整个数组传递过去。实际上只把数组的首元素的地址传递过去.
即使写成数组的形式int arr[], 但它依然是一个指针int*arr.
6.数组传参必须要知道数组元素的个数,然后在以参数的形式传给函数。

举例3.传参过程中没有将长度传递给函函数
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
void Func(int arr[]){
	printf("%d\n", sizeof (arr) / sizeof(arr[0]));
}
int main(){
	int arr[] = { 1, 3, 4, 5 };
	Func(arr);
	printf("%d\n", sizeof (arr) / sizeof(arr[0]));
	system("pause");
	return 0;
}

运行结果:
在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值