给定一个m行n列有序矩阵,查找数k的最优算法的最坏情况复杂度?


下面是最优算法: 


记矩阵的右上角(左下角也可以)元素为a,搜索起点设置为a,要查找的元素为k:
若a>k,则a所在列的所有元素均大于k,搜索位置左移1位,然后删除该列构成新的矩阵;
若a<k,则a所在行的所有元素均小于k,搜索位置下移1位,然后删除该行构成新的矩阵;
若相等,结束查找;
由新构成的矩阵利用上述方式继续查找(递归调用)。 

该最优算法的最坏情况也就是说从右上角开始搜索直到左下角结束,每次向左或向下一步,共需要m+n步到达左下角
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用矩阵快速幂算法,其时间复杂度为O(n^3*logk)。 具体实现步骤如下: 1.定义一个矩阵结构体,包含矩阵组。 2.实现矩阵乘法运算函matrix_multiply(),接受两个矩阵作为参,返回它们的乘积矩阵。 3.实现矩阵快速幂算法power_matrix(),接受一个矩阵一个k作为参,返回矩阵的k次幂。 4.在power_matrix()函,先判断k的大小,当k为1时直接返回原矩阵;当k为偶时,将原矩阵的半次幂矩阵相乘即可得到k次幂矩阵;当k为奇时,先计算原矩阵的半次幂矩阵,再将其与原矩阵相乘,即可得到k次幂矩阵。 代码如下: ```c #include<stdio.h> #include<stdlib.h> /* 定义矩阵结构体 */ typedef struct { int row; // 矩阵 int col; // 矩阵 int **data; // 矩阵组 } Matrix; /* 矩阵乘法 */ Matrix matrix_multiply(Matrix m1, Matrix m2) { Matrix res; res.row = m1.row; res.col = m2.col; res.data = (int**)malloc(res.row * sizeof(int*)); for(int i=0; i<res.row; i++) { res.data[i] = (int*)malloc(res.col * sizeof(int)); for(int j=0; j<res.col; j++) { res.data[i][j] = 0; for(int k=0; k<m1.col; k++) { res.data[i][j] += m1.data[i][k] * m2.data[k][j]; } } } return res; } /* 矩阵快速幂 */ Matrix power_matrix(Matrix m, int k) { if(k == 1) { return m; } Matrix half_res = power_matrix(m, k/2); if(k % 2 == 0) { return matrix_multiply(half_res, half_res); } else { return matrix_multiply(matrix_multiply(half_res, half_res), m); } } int main() { int n = 3; // 矩阵 int k = 3; // 矩阵的次幂 Matrix m; m.row = n; m.col = n; m.data = (int**)malloc(n * sizeof(int*)); for(int i=0; i<n; i++) { m.data[i] = (int*)malloc(n * sizeof(int)); } // 初始化矩阵 m.data[0][0] = 1; m.data[0][1] = 2; m.data[0][2] = 3; m.data[1][0] = 4; m.data[1][1] = 5; m.data[1][2] = 6; m.data[2][0] = 7; m.data[2][1] = 8; m.data[2][2] = 9; Matrix res = power_matrix(m, k); // 打印矩阵的k次幂 for(int i=0; i<n; i++) { for(int j=0; j<n; j++) { printf("%d ", res.data[i][j]); } printf("\n"); } // 释放内存 for(int i=0; i<n; i++) { free(m.data[i]); free(res.data[i]); } free(m.data); free(res.data); return 0; } ``` 注意:以上代码矩阵据类型为整,如果是实,则需要将矩阵乘法运算的加法和乘法改为实的加法和乘法。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值