增量数组查找

在一个二维数组中,每一行都有着按照从左到右的递增顺序排序,每一列都按照从上到下的顺序递增排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该函数

如数组

int[][] a ={{1,2,8,9},

              {2,4,9,12}, 

             {4,7,10,13}, 

             {6,8,11,15}};

方法是按照数组的递增特性,从有上角或者左下角开始,分别和要查找的数num比较;

如从右上角开始, 如果num=a[i][j],则返回true

                            如果num>a[i][j],则去掉该行,因为该行所有数都会小于num;---即行增加1(i++)

                           否则,num<a[i][j],去掉该列,因为该列所有数都大于num;----即列减少1(j--)


这样就能缩小查找的范围

代码如下:

	private static boolean find(int[][] a, int num) {
		// TODO Auto-generated method stub
		int row =a.length-1;
		int column=a.length-1;
		int i = 0,j = column;
		if((num<a[0][0])||(num>a[row][column])){
			return false;
		}else{
			while(i<=row&&j>=0){
				if(a[i][j]==num){
					return true;
				}else if(num>a[i][j]){
					i++;
				}else{
					j--;
				}
			}
		}
		return false;
	}




                                

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我会尽力回答你的问题。关于你的问题,我了解到你需要对一个长度为n的n个关键字值序列,进行希尔排序和冒泡排序,输出每趟希尔排序和冒泡排序的结果。那么,我这里给你提供一份C语言代码,希望能够帮到你。 ``` #include <stdio.h> #include <stdlib.h> void shell_sort(int arr[], int n); // 希尔排序 void bubble_sort(int arr[], int n); // 冒泡排序 void print_array(int arr[], int n); // 打印数组 int main() { int n; printf("请输入序列长度:"); scanf("%d", &n); int arr[n]; printf("请输入%d个关键字值:", n); for (int i = 0; i < n; i++) { scanf("%d", &arr[i]); } printf("希尔排序结果:\n"); shell_sort(arr, n); printf("冒泡排序结果:\n"); bubble_sort(arr, n); return 0; } void shell_sort(int arr[], int n) { int inc[3] = {5, 3, 1}; // 增量数组 int rounds = 3; // 轮数 for (int i = 0; i < rounds; i++) { int d = inc[i]; printf("第%d趟希尔排序,增量为%d:\n", i + 1, d); // 直接插入排序 for (int j = d; j < n; j++) { int temp = arr[j]; int k = j - d; while (k >= 0 && arr[k] > temp) { arr[k + d] = arr[k]; k -= d; } arr[k + d] = temp; } print_array(arr, n); } } void bubble_sort(int arr[], int n) { int rounds = n - 1; // 轮数 int count = 0; // 比较次数 for (int i = 0; i < rounds; i++) { printf("第%d轮冒泡排序:\n", i + 1); for (int j = 0; j < n - 1 - i; j++) { count++; if (arr[j] > arr[j + 1]) { int temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } print_array(arr, n); } printf("冒泡排序比较了%d轮,共计%d次比较\n", rounds, count); } void print_array(int arr[], int n) { for (int i = 0; i < n; i++) { printf("%d ", arr[i]); } printf("\n"); } ``` 上述代码中,我们先通过 `scanf` 获取输入的序列长度和关键字值,然后对其进行希尔排序和冒泡排序。希尔排序中,我们采用增量数组 `{5, 3, 1}`,即先以步长为5进行排序,再以步长为3进行排序,最后以步长为1进行排序。每趟排序都会输出排序结果。冒泡排序中,我们先计算出需要比较的轮数和总比较次数,然后进行排序并输出每轮排序结果。 希望上述代码对你有所帮助!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值