| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 400 人关注过本帖
标题:数组的循环问题
只看楼主 加入收藏
jomwang
Rank: 2
等 级:论坛游民
帖 子:12
专家分:16
注 册:2010-1-28
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:3 
数组的循环问题
这是个二维数组输入值之后取其中的最大的值以及对应的下标的。(这是个例题)
在此有个疑问:怎么实现数组b[][4]行数的不定,也就是说行是可变的,只要开始输入对应的行数即可。
比如说:输入的是2  那就是b[2][4],然后再输入数组里的数值。
也可以只输入一组数,以第一个数作为行数,后面的数作为数组里的数。
其实这个问题觉得要么很简单,要么就不容易,呵呵。

#include <stdio.h>
int max(int a[][4],int n,int *r,int *c);
void main()
{

    int b[3][4];
    int i,j,m,r,c;
    printf("please input the numbers:\n");
    for(i=0;i<3;i++)
        for(j=0;j<4;j++)
            scanf("%d",&b[i][j]);
    for(i=0;i<3;i++)
    {
        for(j=0;j<4;j++)
        printf(" %d",b[i][j]);
        printf("\n");
    }
        
    m=max(b,3,&r,&c);
    printf("\n the max number is: max= %d\n",m);
    printf("theirs position is : r= %d,c= %d\n",r,c);

}
int max(int a[][4],int n,int *r,int *c)
{
    int i,j,m;
    m=a[0][0];
    *r=0;
    *c=0;
    for(i=0;i<n;i++)
        for(j=0;j<4;j++)
            if(m<a[i][j])
            {
                m=a[i][j];
                *r=i;
                *c=j;

            }

    return(m);

}

[ 本帖最后由 jomwang 于 2010-2-1 17:29 编辑 ]
搜索更多相关主题的帖子: please numbers include 最大的 
2010-02-01 17:06
playmyself
Rank: 5Rank: 5
来 自:第3系4级宇宙空间
等 级:职业侠客
帖 子:76
专家分:399
注 册:2009-7-8
收藏
得分:20 
使用内存申请实现变长数组,输入第一个数为数组长度,后面的和你的程序一样。
程序代码:
#include <stdio.h>
#include <stdlib.h> //内存管理的头文件
int max(int a[][4],int n,int *r,int *c);
int main()
{
    //int b[3][4];
    int (* b)[4];  //申请指向4个整形的指针
    int len;
    int i,j,m,r,c;
    printf("Len?\n");    
    scanf("%d", &len);
    b = (int (*)[4])malloc(len * sizeof(int)); //申请内存 
    if(b == NULL) //如果失败提示错误并退出 
    {
        puts("Memory Error!");
        exit(EXIT_FAILURE);
    }
    printf("please input the numbers:\n");
    for(i=0;i<len;i++)
        for(j=0;j<4;j++)
            scanf("%d",&b[i][j]);
    for(i=0;i<len;i++)
    {
        for(j=0;j<4;j++)
        printf(" %d",b[i][j]);
        printf("\n");
    }

    m=max(b,len,&r,&c);
    printf("\n the max number is: max= %d\n",m);
    printf("theirs position is : r= %d,c= %d\n",r,c);
    free(b); 

}
int max(int a[][4],int n,int *r,int *c)
{
    int i,j,m;
    m=a[0][0];
    *r=0;
    *c=0;
    for(i=0;i<n;i++)
        for(j=0;j<4;j++)
            if(m<a[i][j])
            {
                m=a[i][j];
                *r=i;
                *c=j;
            }
    return(m);

}
CFREE4.1 accept..

无聊创造奇迹。
2010-02-01 18:04
playmyself
Rank: 5Rank: 5
来 自:第3系4级宇宙空间
等 级:职业侠客
帖 子:76
专家分:399
注 册:2009-7-8
收藏
得分:0 
你的程序代码风格很好,看得很舒服。。。

无聊创造奇迹。
2010-02-01 18:05
Alen0128
Rank: 4
等 级:业余侠客
帖 子:171
专家分:222
注 册:2009-12-26
收藏
得分:0 
如果,我要实现多个字符串数组的输入怎么处理?

-不想让你发现我 凌乱的脚步 ,我努力 跟上你的速度
2010-02-02 08:38
快速回复:数组的循环问题
数据加载中...
 
   



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

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