求矩阵的鞍点

题目:求一个矩阵的鞍点,即行上最小而列上最大的元素。

代码:(多个最小值认为第一个为最小,更严谨的代码在最后)

cpp 复制代码
#include<iostream>
#include<time.h>
using namespace std;

int main(){
	int n,m;
	cout<<"请输入矩阵的行数和列数: "<<endl;
	cin>>n>>m;
	int a[n+1][m+1];
	srand(time(NULL));
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			a[i][j]=rand()%10;
		}
	}

//	a[1][1]=5;a[1][2]=10;a[1][3]=15;
//	a[2][1]=2;a[2][2]=7;a[2][3]=8;
//	a[3][1]=1;a[3][2]=9;a[3][3]=10;
//	cout<<"矩阵为:"<<endl; 
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			cout<<a[i][j]<<" ";
		}
		cout<<endl;
	}
	int cnt=0;//cnt个鞍点 
	for(int i=1;i<=n;i++){ 
		//找第i行的最小值的列数 
		int min=a[i][1],mini=1;
		for(int j=1;j<=m;j++){
			if(min>a[i][j]){
				min=a[i][j];
				mini=j; 
			}
		} 
		bool flag=true;
		//判断第mini列上a[i][mini]是否为最大
		for(int k=1;k<=n;k++){
			if(a[k][mini]>a[i][mini]){
				flag=false;
				break;
			}
		} 
		if(flag){
			cnt++;
			cout<<"鞍点:"<<a[i][mini]<<endl;
		}
	}
	if(cnt==0){
		cout<<"没有鞍点"<<endl;
	} 
	return 0;
}

代码:

cpp 复制代码
#include<iostream>
#include<time.h>
using namespace std;

void maxJ(int mini){//判断第mini列上a[i][mini]是否为最大

}
int main(){
	int n,m;
	cout<<"请输入矩阵的行数和列数: "<<endl;
	cin>>n>>m;
	int a[n][m];
//	srand(time(NULL));
//	for(int i=1;i<=n;i++){
//		for(int j=1;j<=m;j++){
//			a[i][j]=rand()%10;
//		}
//	}
	a[1][1]=5;a[1][2]=5;a[1][3]=15;
	a[2][1]=2;a[2][2]=2;a[2][3]=8;
	a[3][1]=1;a[3][2]=1;a[3][3]=10;
	cout<<"矩阵为:"<<endl; 
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			cout<<a[i][j]<<" ";
		}
		cout<<endl;
	}
	int cnt=0;//cnt个鞍点 
	for(int i=1;i<=n;i++){ 
		//找第i行的最小值的列数(可能有多个)
		int minValue=a[i][1],mini[m],min_cnt=0;
		for(int j=1;j<=m;j++){
			if(minValue>a[i][j]){
				min_cnt=0;
				minValue=a[i][j];
				mini[min_cnt++]=j;
			}else if(minValue==a[i][j]){
				mini[min_cnt++]=j; 
			}
		} 
		//判断第mini列上a[i][mini]是否为最大
		bool flag=true;
		for(int mcnt=0;mcnt<min_cnt;mcnt++){
			bool flag=true;
			for(int k=1;k<=n;k++){
				if(a[k][mini[mcnt]]>a[i][mini[mcnt]]){
					flag=false;
					break;
				}
			} 
			if(flag){
				cnt++;
				cout<<"鞍点:"<<a[i][mini[mcnt]]<<" 位置:x="<<i<<",y="<<mini[mcnt]<<endl;
			}
		}
	}
	if(cnt==0){
		cout<<"没有鞍点"<<endl;
	} 
	return 0;
}
相关推荐
泽02022 分钟前
C++之STL--list
开发语言·c++·list
BUG收容所所长11 分钟前
二分查找的「左右为难」:如何优雅地找到数组中元素的首尾位置
前端·javascript·算法
itsuifengerxing1 小时前
python 自定义无符号右移
算法
猎板PCB厚铜专家大族1 小时前
高频 PCB 技术发展趋势与应用解析
人工智能·算法·设计规范
dying_man1 小时前
LeetCode--24.两两交换链表中的结点
算法·leetcode
yours_Gabriel1 小时前
【力扣】2434.使用机器人打印字典序最小的字符串
算法·leetcode·贪心算法
Dovis(誓平步青云)2 小时前
探索C++标准模板库(STL):String接口的底层实现(下篇)
开发语言·c++·stl·string
Psycho_MrZhang2 小时前
高等数学基础(矩阵基本操作转置和逆矩阵)
线性代数·矩阵
草莓熊Lotso2 小时前
【数据结构初阶】--算法复杂度的深度解析
c语言·开发语言·数据结构·经验分享·笔记·其他·算法
KyollBM2 小时前
【CF】Day75——CF (Div. 2) B (数学 + 贪心) + CF 882 (Div. 2) C (01Trie | 区间最大异或和)
c语言·c++·算法