C语言初学者r 2023-03-30 02:51 采纳率: 91.7%
浏览 33
已结题

【二维数组+指针】【】求二维数组每行的最大值

代码中00的地方不知道填什么形式,是p[i][j],还是*(*(p+i)+j)还是其他。(两个@@1之间是要填写代码,@#1所在位置相当于空格要填写代码)
题目

img


题目源代码

#include"stdio.h"
void init_array(int *p1);
void getmax(int *p1,int s[]);

main()
{
    int b[3][4],s[3];
    int i;
    init_array(@#1);
    getmax(@#3,s);
    for(i=0;i<3;i++)
        printf("row%d:  max=%d\n",i,s[i]);    
}

void init_array(@#4)
{
    int i,j;
    for(i=0;i<3*4;i++)
        scanf("%d",@#5);
    
}

void getmax(int *p1,int s[])   
{
    int i,j,max;
    for(i=0;i<3;i++)
    {
        max=@#6    //取最大值为每行的第一个单元格的值
                   //从每行的第二列单元格到最后一个单元格逐个比较   
        for(j=1;j<4;j++)
             @@1

                @@1
        s[i]=max;    
    }    
}

我所写的(00处是要修改部分)

#include"stdio.h"
void init_array(int *p1);
void getmax(int *p1,int s[]);

main()
{
    int b[3][4],s[3];
    int i;
    init_array(b);
    getmax(b,s);
    for(i=0;i<3;i++)
        printf("row%d:  max=%d\n",i,s[i]);    
}

void init_array(int *p1)
{
    int i,j;
    for(i=0;i<3*4;i++)
        scanf("%d",(p1+i));
    
}

void getmax(int *p1,int s[])   
{
    int i,j,max;
    for(i=0;i<3;i++)
    {
        max= 00//;      
        for(j=1;j<4;j++)
             //@@1
          if(00>max)
          {
              max= 00;
          }
                //@@1
        s[i]=max;    
    }    
}

展开全部

  • 写回答

4条回答 默认 最新

  • threenewbee 2023-03-30 02:55
    关注

    指针和下标都是可以的,但是指针的话,应该是 (s+i4+j)

    #include"stdio.h"
    void init_array(int *p1);
    void getmax(int *p1,int s[]);
     
    int main()
    {
        int b[3][4],s[3];
        int i;
        init_array(b);
        getmax(s, b);
        for(i=0;i<3;i++)
            printf("row%d:  max=%d\n",i,s[i]);    
    }
     
    void init_array(int *p1)
    {
        int i,j;
        for(i=0;i<3*4;i++)
            scanf("%d",(p1+i));    
    }
    
    void getmax(int *p1,int s[])   
    {
        int i,j,max;
        for(i=0;i<3;i++)
        {
            max= s[i][0];     
            for(j=1;j<4;j++)
            {
              if(s[i][j]>max)
              {
                  max= s[i][j];
              }
            *p1[i]=max;    
        }    
    }
    
    

    展开全部

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 4月10日
  • 已采纳回答 4月3日
  • 创建了问题 3月30日

悬赏问题

  • ¥15 编译python程序为pyd文件报错:{"source code string cannot contain null bytes"
  • ¥20 关于#r语言#的问题:广义加行模型拟合曲线后如何求拐点
  • ¥15 fluent设置了自动保存后,会有几个时间点不保存
  • ¥20 激光照射到四象线探测器,通过液晶屏显示X、Y值
  • ¥15 这怎么做,怎么在我的思路下改下我这写的不对
  • ¥50 数据库开发问题求解答
  • ¥15 安装anaconda时报错
  • ¥15 小程序有个导出到插件方式,我是在分包下引入的插件,这个export的路径对吗,我看官方文档上写的是相对路径
  • ¥20 希望有人能帮我完成这个设计( *ˊᵕˋ)
  • ¥100 将Intptr传入SetHdevmode()将Intptr传入后转换为DEVMODE的值与外部代码不一致
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部