编写函数 test2,判断一个矩阵a是否存在鞍点,若存在返回真。鞍点位置及值存放在数组b[][3]中返回主函数,不存在返回假。//要求用指向常量的指针做形参,并用指针法访问/引用矩阵中的元素
bool test2(const int*p, int b[][3], int &n) // n,鞍点个数,返回是否有鞍点
关于#c++#的问题:判断一个矩阵a是否存在鞍点,若存在返回真。
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- CSDN专家-天际的海浪 2022-07-02 04:24关注
你题目的解答代码如下:
#include <iostream> using namespace std; int M, N; bool test2(const int*p, int b[][3], int &n) { int i, j, x, y, sign; n = 0; for (x = 0; x < M; x++) { for (y = 0; y < N; y++) { sign = 1; for (i = 0; i < N; i++) { if (*(p+x*N+y) < *(p+x*N+i)) sign = 0; } for (j = 0; j < M; j++) { if (*(p+x*N+y) > *(p+j*N+y)) sign = 0; } if (sign == 1) { b[n][0] = x; b[n][1] = y; b[n][2] = *(p+x*N+y); n++; } } } return n != 0; } int main() { int b[100][3]; int i, j, n; cout << "输入行数M,列数N" << endl; cin >> M >> N; int a[M][N]; cout << "输入矩阵" << endl; for (i = 0; i < M; i++) for (j = 0; j < N; j++) cin >> a[i][j]; if (test2((int *)a, b, n)) { cout << "鞍点是" << endl; for (i = 0; i < n; i++) cout << "a[" << b[i][0] << "][" << b[i][1] << "]=" << b[i][2] << endl; } else { cout << "没有鞍点" << endl; } return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥50 我撰写的python爬虫爬不了 要爬的网址有反爬机制
- ¥15 Centos / PETSc / PETGEM
- ¥15 centos7.9 IPv6端口telnet和端口监控问题
- ¥120 计算机网络的新校区组网设计
- ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作
- ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
- ¥20 海浪数据 南海地区海况数据,波浪数据
- ¥20 软件测试决策法疑问求解答
- ¥15 win11 23H2删除推荐的项目,支持注册表等
- ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法