、构造一个4行4列的矩阵,每个元素值为行列下标的和,分别求对角线的和、上三角的和、下三角的和。

、构造一个4行4列的矩阵,每个元素值为行列下标的和,分别求对角线的和、上三角的和、下三角的和。

参考如下:

#include <stdio.h>

int main()
{
    int a[4][4], i, j, sumA = 0, sumB = 0, sumC = 0;
    for (i = 0; i < 4; i++)
    {
        for (j = 0; j < 4; j++)
        {
            a[i][j] = i + j;
            if (i == j || i == 3 - j)
                sumA += a[i][j]; // 对角线的和(主对角线+次对角线)
            
        }
        for (j = 0; j <= i; j++)
        {
            sumB += a[i][j]; // 上三角的和
        }
        
        for(j = 3; j>=i; j--)
        {
            sumC += a[i][j]; // 下三角的和
        }
    }
    
    printf("对角线的和 = %d\n", sumA);
    printf("上三角的和 = %d\n", sumB);
    printf("下三角的和 = %d", sumC);
   
   return 0;
}

  • 这有个类似的问题, 你可以参考下: https://ask.csdn.net/questions/7536270
  • 这篇博客你也可以参考下:编写程序,输入三角形的3边长,求其面积。注意:三角形的任意两边之和必须大于第3边,对于不合理的边长输入,要求给出错误提示。
  • 除此之外, 这篇博客: 输入十个数,将最小的与第一个交换,最大的与最后一个交换 写三个函数:输入10个数,进行处理,输出10个数中的 输入十个数,将最小的与第一个交换,最大的与最后一个交换 写三个函数:输入10个数,进行处理,输出10个数 部分也许能够解决你的问题, 你可以仔细阅读以下内容或跳转源博客中阅读:
  • 题目来源:《谭浩强C语言程序设计》指针习题3
    - 思路
    1.编写输入输出函数。
    2.编写能够找出最大值和最小值并按照:最小的与第一个交换,最大的与最后一个交换的要求进行编写。
    (1)定义三个指针变量*max,*p,*min,使得开始的时候三者都指向同一个地址;
    (2)先找的最大的和最小的数
    (3)交换(借助中间变量temp)交换最大的与最后一个交换; 最小的与第一个交换。
    3.在主函数中对三个函数分别进行调用。

    - 注意事项:
    如果先 最小的与第一个交换,那么如果第一个就是最大的先与最后一个交换之后,max和min指向的地址是没有变化的,但是此时最大的数的值变化了
    变成了最后一个数,所以要加下面这一句:if (max == number)max = min;
    代码部分如下:

      temp = number[0];
        number[0] = *min;
        *min = temp;
        if (max == number)max = min;
      temp = number[9];
        number[9] = *max;
        *max = temp;
    

    具体代码

    // Created by acer on 2020/5/12.
    //输入十个数,将最小的与第一个交换,最大的与最后一个交换 写三个函数:输入10个数,进行处理,输出10个数
    #include <stdio.h>
    
    void output(int *number);  //函数声明
    
    void print(int *number);
    
    void max_min(int *number);
    
    int main() {
        int number[10];
    //    函数调用
        print(number);
        max_min(number);
        output(number);
        return 0;
    }
    
    void print(int *number) {    //输入函数
        for (int i = 0; i < 10; i++) {
            scanf("%d", &number[i]);
        }
    }
    
    void max_min(int *number) {
        int *p, *max, *min, temp;
        max = min = number;
    //    1.先找的最大的和最小的
        for (p = number; p < number + 10; p++) {
            if (*p > *max)max = p;  //把p指向地址给max,使得如果*p大于*max就让max指向p所指的数
            else if (*p < *min)min = p;//把p指向地址给min,使得如果*p小于*max就让min指向p所指的数
        }
    //    2.交换最大的与最后一个交换
        temp = number[9];
        number[9] = *max;
        *max = temp;
    
        /*特殊情况:如果第一个就是最大的先与最后一个交换之后,max和min指向的地址是没有变化的,但是此时最大的数的值变化了
      变成了最后一个数,所以要加下面这一句if (max == number)max = min;*/
    //    最小的与第一个交换
        temp = number[0];
        number[0] = *min;
        *min = temp;
    }
    
    void output(int *number) {  //输出函数
        int *p;
        printf("请输入十个数字\n");
        for (p = number; p < number + 10; p++) {
            printf("%d", *p);
            printf(" ");
        }
    
    
    }
    

    结果

    98 24 56 78 1 32 36 44 29 6
    请输入十个数字
    1 24 56 78 6 32 36 44 29 98
    
  • 您还可以看一下 李月喜老师的企业微信开发第三方应用开发篇课程中的 第三方市场分析,安装试用第三方网页应用及小程序应用,了解安装及授权安装流程小节, 巩固相关知识点
  • 以下回答由chatgpt基于相关博客总结生成:
    # 构造4行4列的矩阵
    matrix = [[i+j for j in range(4)] for i in range(4)]
    
    # 计算对角线、上三角、下三角的和
    diag = 0  # 对角线和
    up_tri = 0  # 上三角和
    low_tri = 0  # 下三角和
    for i in range(4):
        for j in range(4):
            if i == j:
                diag += matrix[i][j]
            if i < j:
                up_tri += matrix[i][j]
            if i > j:
                low_tri += matrix[i][j]
    
    print("构造的矩阵为:")
    for i in range(4):
        for j in range(4):
            print(matrix[i][j], end=" ")
        print()
    print("对角线和为:", diag)
    print("上三角和为:", up_tri)
    print("下三角和为:", low_tri)
    

    输出结果为:

    构造的矩阵为:
    0 1 2 3 
    1 2 3 4 
    2 3 4 5 
    3 4 5 6 
    对角线和为: 12
    上三角和为: 33
    下三角和为: 24