c语言编译错误,数组

题目描述
现有 N 名同学参加了期末考试,并且获得了每名同学的信息:语文、数学、英语成绩(均为不超过 150的自然数)。如果某对学生的每一科成绩的分差都不大于 5,且总分分差不大于 10,那么这对学生就是“旗鼓相当的对手”。现在想知道这些同学中,有几对“旗鼓相当的对手”?同样一个人可能会和其他好几名同学结对。

输入格式
第一行一个正整数N。接下来 N 行,每行三个整数,其中第 j行表示第 j 名同学的语文、数学、英语成绩。

输出格式
输出一个整数,表示“旗鼓相当的对手”的对数。


#include<stdio.h>
#include<stdlib.h>
#include<math.h>
int main()
{
    int n,i,j,sum[1000];
    int a[3][];
    scanf("%d\n",&n);
    for(i=0;i<=2;i++)
    {
        for(j=0;j<=n-1;j++)
        {
            scanf("%d",&a[i][j]);
        }
    }
    for(j=0;j<=n-1;j++)
    {
        sum[j]=a[0][j]+a[1][j]+a[2][j];
    }
    int c=0;
    for(j=0;j<=n-1;j++)
    {
        for(int k=j+1;k<n;k++)
        {
            if((abs(a[0][j]-a[0][k])<=5)&&(abs(a[1][j]-a[1][k])<=5)&&(abs(a[2][j]-a[2][k])<=5)&&(abs(sum[j]-sum[k])<=10))
            {
                c++;
            }
        }
    }
    printf("%d",c);
    return 0;
}
    int n,i,j,sum[1000];
    scanf("%d\n",&n);
    int a[3][n];

声明数组第二个参数n

【以下回答由 GPT 生成】

问题出在这里:int a[3][]; // 这里是数组不完整声明的地方

在C语言中,你需要在声明数组时指定数组的大小,甚至是二维数组。所以,你需要修改数组的声明,为每一个维度都指定大小。另外,你还需要注意数组的索引范围和循环条件。

这是修复后的代码:

#include<stdio.h>
#include<stdlib.h>
#include<math.h>

int main()
{
    int n,i,j,sum[1000];
    int a[3][1000]; // 修复数组声明

    scanf("%d\n",&n);
    for(i=0;i<=2;i++)
    {
        for(j=0;j<=n-1;j++)
        {
            scanf("%d",&a[i][j]);
        }
    }
    for(j=0;j<=n-1;j++)
    {
        sum[j]=a[0][j]+a[1][j]+a[2][j];
    }
    int c=0;
    for(j=0;j<=n-1;j++)
    {
        for(int k=j+1;k<n;k++)
        {
            if((abs(a[0][j]-a[0][k])<=5)&&(abs(a[1][j]-a[1][k])<=5)&&(abs(a[2][j]-a[2][k])<=5)&&(abs(sum[j]-sum[k])<=10))
            {
                c++;
            }
        }
    }
    printf("%d",c);
    return 0;
}

这样,你的代码就能够成功编译并运行了。



【相关推荐】


  • 这个问题的回答你可以参考下: https://ask.csdn.net/questions/7737102
  • 除此之外, 这篇博客: 纸牌游戏(C语言实现)中的 星期天小哼和小哈约在一起玩桌游,他们正在玩一个非常古怪的扑克游戏——“小猫钓鱼”。游戏的规则是这样的:将一副扑克牌平均分成两份,每人拿一份。小哼先拿出手中的第一张扑克牌放在桌上,然后小哈也拿出手中的第一张扑克牌,并放在小哼刚打出的扑克牌的上面,就像这样两人交替出牌。出牌时,如果某人打出的牌与桌上某张牌的牌面相同,即可将两张相同的牌及其中间所夹的牌全部取走,并依次放到自己手中牌的末尾。当任意一人 手中的牌全部出完时,游戏结束,对手获胜。 部分也许能够解决你的问题。

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^

将第10行和第12行调换一下位置,然后定义a为3x1000的二维数组即可。

修改如下:

参考链接:

P5728 【深基5.例5】旗鼓相当的对手_第2题 旗鼓相当的对手 查看测评数据信息 现有 n(n≤1000) 名同学参加了期末考试,_Kunkun只喝怡宝的博客-CSDN博客 题目描述现有 N(N≤1000) 名同学参加了期末考试,并且获得了每名同学的信息:语文、数学、英语成绩(均为不超过 150 的自然数)。如果某对学生 的每一科成绩的分差都不大于 5,且总分分差不大于 10,那么这对学生就是“旗鼓相当的对手”。现在想知道这些同学中,有几对“旗鼓相当的对手”?同样一个人可能会和其他好几名同学结对。输入格式第一行一个正整数 N。接下来 N 行,每行三个整数,其中第 i 行表示第 i 名同学的语文、数学、英语成绩。最先读入的同学编号为 1。输出格式_第2题 旗鼓相当的对手 查看测评数据信息 现有 n(n≤1000) 名同学参加了期末考试, https://blog.csdn.net/Z_H86/article/details/116544113


 
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
int main()
{
    int n,i,j,sum[1000];
    
    scanf("%d",&n);
    int a[3][1000];  // 3行依次存储最多1000名学生的 语文,数学,英语成绩 
    
    for(j=0;j<=n-1;j++)
     {
         for(i=0;i<=2;i++) // 读取每行输入的语文、数学、英语成绩,存入二维数组3行相应的位置 
            {
            scanf("%d",&a[i][j]);
        }
    }
    for(j=0;j<=n-1;j++)
    {
        sum[j]=a[0][j]+a[1][j]+a[2][j];
    }
    int c=0;
    for(j=0;j<n-1;j++)
    {
        for(int k=j+1;k<n;k++)
        {
            if((abs(a[0][j]-a[0][k])<=5)&&(abs(a[1][j]-a[1][k])<=5)&&(abs(a[2][j]-a[2][k])<=5)&&(abs(sum[j]-sum[k])<=10))
            {
                c++;
            }
        }
    }
    printf("%d",c);
    return 0;
}

img