/*An,m是一个n行m列的矩阵;Aij表示A的第i行j列的元素;定义xij为A的
第i行和第j列除了ai,j之外所有元素(共n+m-2个)的乘积,即xi,j=ai,1*ai,2*...*ai,j-1
..*ai,m*a1,j*a2,j...*ai-1,j*ai+1,j...*an,j现输入非负整形的矩阵An,m求MAX(xi,j),即所有xi,j中的最大值。
输入描述:第一行两个整数n和m。之后n行输入矩阵,均为非负整数
实例:
输入:3 5
5 1 8 5 2
1 3 10 3 3
7 8 5 5 16
输出:358400*/
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int n,m;//n是行数,m是列数
int count(int(*arr)m,int n,int m,int subi,int subj)
{
int ret=1;
for(int i=0;i<n;i++)
{
if(i!=subi)
{
ret*=arrisubj;
}
}
for(int j=0;j<m;j++)
{
if(j!=subj)
{
ret*=arrsubij;
}
}
return ret;
}
int main(int argc,const char * argv\[\])
{
printf("请输入行数和列数\n");
scanf("%d %d",&n,&m);
int arrnm;
for(int i=0;i<n;i++)
{
for(int j=0;j<m;j++)
{
printf("请输入第%d行第%d个元素为:\n",i+1,j+1);
scanf("%d",&arrij);getchar();
}
}
int max=count(arr,n,n,0,0);
int temp;
for(int i=0;i<n;i++)
{
for(int j=0;j<m;j++)
{
if(0==i&&0==j)
break;
temp=count(arr,n,m,i,j);
if(temp>max)
max=temp;
}
}
printf("最大值为:%d\n",max);
return 0;
}
逻辑题(重点!)
像鱼4702023-07-22 23:10
相关推荐
小欣加油1 小时前
leetcode56 合并区间lqqjuly1 小时前
前沿算法深度解析(二)徐小夕3 小时前
万字长文!千万级文档 RAG 知识库系统落地实践akunkuntaimei3 小时前
2026年高考数学各省真题及答案(完整版)Hello:CodeWorld4 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南8Qi85 小时前
LeetCode 516:最长回文子序列十月的皮皮5 小时前
C语言学习笔记20260606- 求月份天数三种写法youngerwang6 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】想要成为糕糕手6 小时前
前端必修课:JavaScript 数组与数据结构底层逻辑全解析KaMeidebaby6 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解