| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 434 人关注过本帖
标题:求助!!帮我看看数组问题
只看楼主 加入收藏
缘中月
Rank: 2
来 自:福建
等 级:论坛游民
帖 子:50
专家分:18
注 册:2010-2-25
结帖率:100%
收藏
 问题点数:0 回复次数:6 
求助!!帮我看看数组问题
#include<stdio.h>
void main()
{
    int i,j,k,max,maxj,a[3][3],flag;
    for(i=0;i<3;i++)
        for(j=0;j<3;j++)
            scanf("%d",&a[i][j]);
    for(i=0;i<3;i++)
   {
        max=a[i][0];
        maxj=0;
        for(j=0;j<3;j++)
        {
            if(a[i][j]>max)
                max=a[i][j];
                maxj=j;
        }
    }
        flag=1;
        for(k=0;k<3;k++)
        {
            if(max>a[k][maxj])
            {
                flag=0;
                break;
            }

        }
     for(i=0;i<3;i++)
     {
        for(j=0;j<3;j++)
            printf("%3d",a[i][j]);
        printf("\n");
     }
        
        if(flag)
        {
            printf("a[%d][%d]=%d\n",i,maxj,max);
            
        }
        if(!flag)
            printf("it is not exist\n");

}  求数组中的鞍点,鞍点是在该位置上的元素在该行上最大载该列上最小。程序可以运行但是出不来正确的结果。 谁帮我看看哪里错了~谢谢

[ 本帖最后由 缘中月 于 2010-5-18 20:26 编辑 ]
2010-05-18 19:55
NoSoul
Rank: 9Rank: 9Rank: 9
来 自:沈阳化工大学
等 级:蜘蛛侠
帖 子:283
专家分:1010
注 册:2009-6-6
收藏
得分:0 
#include <stdio.h>
int main()
{
    int a[3][3],i,j,k,l,n=0,row,col=0;
    for(i=0;i<3;i++)
        for(j=0;j<3;j++)
            scanf("%d",&a[i][j]);
    for(i=0;i<3;i++){
        row=i;
        for(j=0;j<3;j++){
            if(a[i][j]>a[row][col]){
                col=j;
            }
        }
        l=1;
        for(k=0;k<3;k++){
            if(a[k][col]<a[row][col]){
                l=0;
                break;
            }
        }
        if(l==1){
            printf("鞍点是%d,在%d行%d列。\n",a[row][col],row+1,col+1);
            n++;
        }
    }
    if(n==0){
        printf("没有鞍点!\n");
    }
    return 0;

}

我想伸手拉近點,竟觸不到那邊,就欠一點點,但這一點點...卻好遠
2010-05-18 19:57
缘中月
Rank: 2
来 自:福建
等 级:论坛游民
帖 子:50
专家分:18
注 册:2010-2-25
收藏
得分:0 
回复 2楼 NoSoul
能解释下吗?看不太懂额?谢谢了
2010-05-18 20:00
NoSoul
Rank: 9Rank: 9Rank: 9
来 自:沈阳化工大学
等 级:蜘蛛侠
帖 子:283
专家分:1010
注 册:2009-6-6
收藏
得分:0 
先找每一行的最大的 然后判断是不是最小的  是的话就是鞍点。。。

我想伸手拉近點,竟觸不到那邊,就欠一點點,但這一點點...卻好遠
2010-05-18 20:07
缘中月
Rank: 2
来 自:福建
等 级:论坛游民
帖 子:50
专家分:18
注 册:2010-2-25
收藏
得分:0 
回复 4楼 NoSoul
我的思路和你一样?为什么我的运行不出来结果?能帮我看看哪错了嘛?
2010-05-18 20:10
NoSoul
Rank: 9Rank: 9Rank: 9
来 自:沈阳化工大学
等 级:蜘蛛侠
帖 子:283
专家分:1010
注 册:2009-6-6
收藏
得分:0 
你自己对照一下吧
#include <stdio.h>
int main()
{
    int i,j,k,maxj,a[3][3],flag,count=0;
    for(i=0; i<3; i++)
        for(j=0; j<3; j++)
            scanf("%d",&a[i][j]);
    for(i=0; i<3; i++)
    {
        for(j=0; j<3; j++)
            printf("%3d",a[i][j]);
        printf("\n");
    }
    for(i=0; i<3; i++)
    {
        maxj=0;
        for(j=1; j<3; j++)
            if(a[i][j]>a[i][maxj])
                maxj=j;
        flag=1;
        for(k=0; k<3; k++)
            if(a[i][maxj]>a[k][maxj])
            {
                flag=0;
                break;
            }
        if(flag)
            printf("a[%d][%d]=%d\n",i,maxj,a[i][maxj]),count++;
    }
    if(count==0)
        printf("it is not exist\n");
    return 0;
}

我想伸手拉近點,竟觸不到那邊,就欠一點點,但這一點點...卻好遠
2010-05-18 21:03
缘中月
Rank: 2
来 自:福建
等 级:论坛游民
帖 子:50
专家分:18
注 册:2010-2-25
收藏
得分:0 
回复 6楼 NoSoul
知道了~谢谢!!
2010-05-19 21:06
快速回复:求助!!帮我看看数组问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.012132 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved