题目描述 读入一个 的数字矩阵, 依次输出将原矩阵顺时针寻旋转90°, 180°, 270° 的数字矩阵 . 输入 读入一个整数 接下来 行, 每行 个数的数字矩阵, 每个数字不会超过10000 样例输入 复制 3 1 2 3 4 5 6 7 8 9 样例输出 复制 7 4 1 8 5 2 9 6 3 9 8 7 6 5 4 3 2 1 3 6 9 2 5 8 1 4 7
## 第一题:求 m 值 ```pascal program CalculateM; function max(x, y, z: real): real; var temp: real; begin temp := x; if y > temp then temp := y; if z > temp then temp := z; max := temp; end; procedure findMax(x, y, z: real; var result: real); var temp: real; begin temp := x; if y > temp then temp := y; if z > temp then temp := z; result := temp; end; var a, b, c, m: real; max1, max2: real; begin readln(a, b, c); m := (a + b + c) / (max(a, b, c) * max(a, b, c)); findMax(a, b, c, max1); max2 := max(a, b, c); writeln(m:0:3); end. ``` ## 第二题:矩阵旋转 ```pascal program MatrixRotation; const MAXN = 100; type TMatrix = array[1..MAXN, 1..MAXN] of integer; var n: integer; mat: TMatrix; procedure readMatrix; var i, j: integer; begin readln(n); for i := 1 to n do for j := 1 to n do read(mat[i, j]); end; procedure rotate90(var src, dest: TMatrix); var i, j: integer; begin for i := 1 to n do for j := 1 to n do dest[j, n - i + 1] := src[i, j]; end; procedure printMatrix(var m: TMatrix); var i, j: integer; begin for i := 1 to n do begin for j := 1 to n do begin write(m[i, j]); if j < n then write(' '); end; writeln; end; end; var mat90, mat180, mat270: TMatrix; begin readMatrix; rotate90(mat, mat90); rotate90(mat90, mat180); rotate90(mat180, mat270); printMatrix(mat90); writeln; printMatrix(mat180); writeln; printMatrix(mat270); end. ``` ## 代码说明 第一题 1. 定义函数 `max` 计算三个数的最大值 2. 定义过程 `findMax` 计算三个数的最大值 3. 根据公式 m = (a+b+c)/(max(a,b,c)²) 计算结果 4. 输出保留三位小数 第二题 1. 定义矩阵类型和旋转函数 2. `rotate90` 函数实现顺时针90度旋转 3. 通过三次旋转得到90°、180°、270°的结果 4. 按格式输出三个旋转后的矩阵 两个程序都符合题目要求,可以直接编译运行。 [2025-12-15 12:24:50 | AI问答 | 685点数解答]
- [字节豆包] 一块 n×n 正方形的黑白瓦片的图案要被转换成新的正方形图案。写一个程序来找出将原始图案按照以下列转换方法转换成新图案的最小方式: 转 90°:图案按顺时针转 90°。 转 180°:图案按顺时针转 180°。 转 270°:图案按顺时针转 270°。 反射:图案在水平方向翻转(以中央铅垂线为中心形成原图案的镜像)。 组合:图案在水平方向翻转,然后再按照 1∼3 之间的一种再次转换。 不改变:原图案不改变。 无效转换:无法用以上方法得到新图案。 如果有多种可用的转换方法,请选择序号最小的那个。 只使用上述 7 个中的一个步骤来完成这次转换。 输入格式 第一行一个正整数 n。 然后 n 行,每行 n 个字符,全部为 @ 或 -,表示初始的正方形。 接下来 n 行,每行 n 个字符,全部为 @ 或 -,表示最终的正方形。 输出格式 单独的一行包括 1∼7 之间的一个数字(在上文已描述)表明需要将转换前的正方形变为转换后的正方形的转换方法。 输入输出样例 输入 #1复制 3 @-@ --- @@- @-@ @-- --@ 输出 #1复制 1 说明/提示 【数据(817点数解答 | 2025-11-25 19:03:09)47
- [DeepSeek] 题目描述 读入一个 的数字矩阵, 依次输出将原矩阵顺时针寻旋转90°, 180°, 270° 的数字矩阵 . 输入 读入一个整数 接下来 行, 每行 个数的数字矩阵, 每个数字不会超过10000 样例输入 复制 3 1 2 3 4 5 6 7 8 9 样例输出 复制 7 4 1 8 5 2 9 6 3 9 8 7 6 5 4 3 2 1 3 6 9 2 5 8 1 4 7(685点数解答 | 2025-12-15 12:24:50)21
- [DeepSeek] 题目描述 读入一个n*n 的数字矩阵, 依次输出将原矩阵顺时针寻旋转90°, 180°, 270° 的数字矩阵 . 输入 读入一个整数n[1,100] 接下来 行, 每行 个数的数字矩阵, 每个数字不会超过10000 样例输入 复制 3 1 2 3 4 5 6 7 8 9 样例输出 复制 7 4 1 8 5 2 9 6 3 9 8 7 6 5 4 3 2 1 3 6 9 2 5 8 1 4 7(311点数解答 | 2025-12-28 17:05:44)24
- [字节豆包] 题目描述 计算两个矩阵的乘法。n×m 阶的矩阵 A 乘以 m×k 阶的矩阵 B 得到的矩阵 C 是 n×k 阶 的,且 C[i][j]=A[i][0]×B[0][j]+A[i][1]×B[1][j]+......+A[i][m−1]×B[m−1][j](C[i][j] 表示 C 矩阵中第 i 行第 j 列元素)。 输入格式 第一行为 n,m,k,表示 A 矩阵是 n 行 m列,B 矩阵是 m行 k列,n,m,k均小于 100。 然后先后输入 A 和 B 两个矩阵,A 矩阵 n 行 m 列,B 矩阵 m 行 k列,矩阵中每个元 素的绝对值不会大于 1000。 输出格式 输出矩阵 C,一共 n 行,每行 k个整数,整数之间以一个空格分开。 输入输出样例 输入 323 11 11 11 111 111 输出 222 222 222 用c++语言(381点数解答 | 2025-12-03 19:20:23)66
- [字节豆包] 题目描述 数学中绝对值的概念是这样的:绝对值表示数轴上的点到原点的距离。既然是一段距离那么就不能是负数。 因此,正数和 0 0 的绝对值就是它们本身,而负数的绝对值是它们的相反数。( 5 5 的相反数是 − 5 −5, − 5 −5 的相反数是 5 5) 请你编写程序,输入一个数 a a,输出 a a 的绝对值。( a a 可能是小数) 输入格式 输入包括一行,包含一个数 a a。 输出格式 输出 a a 的绝对值。 input1 复制 2.5 output1 复制 2.5 input2 复制 -3.3 output2 复制 3.3 提示 如果用 0 0 减去一个数,就能得到这个数的相反数。 数据规模与约定 对于 100 % 100% 的数据, − 10000 < a < 10000 −10000<a<10000。c++(229点数解答 | 2025-07-20 15:22:18)287
- [字节豆包] 题目描述 数学中绝对值的概念是这样的:绝对值表示数轴上的点到原点的距离。既然是一段距离那么就不能是负数。 因此,正数和 0 0 的绝对值就是它们本身,而负数的绝对值是它们的相反数。( 5 5 的相反数是 − 5 −5, − 5 −5 的相反数是 5 5) 请你编写程序,输入一个数 a a,输出 a a 的绝对值。( a a 可能是小数) 输入格式 输入包括一行,包含一个数 a a。 输出格式 输出 a a 的绝对值。 input1 复制 2.5 output1 复制 2.5 input2 复制 -3.3 output2 复制 3.3 提示 如果用 0 0 减去一个数,就能得到这个数的相反数。 数据规模与约定 对于 100 % 100% 的数据, − 10000 < a < 10000 −10000<a<10000。c++(311点数解答 | 2025-10-25 20:10:16)85
- [字节豆包] 由于这个气垫大小有限,所以 x 不能太大。如果 x 超过 50,气垫会自动把 x 修改为 50。 假设某人的体重为 y,只要体重 y 不超过 x ,都可以安全地落在气垫上面(受到的伤害值为0), 如果体重 y 超过 x,就会受伤,受到的伤害值为 y - x。 请你编写一个程序,计算每个人的受到的伤害值。 输入: 共两行。 第一行为两个整数,分别表示掉落人数n,以及给气垫设置的最大承受重量x。 第二行为n个整数,表示每个人的重量。 输出: n 整数,依次表示每个人受到的伤害值,相邻的数字之间用空格隔开。c++(235点数解答 | 2025-10-18 19:23:16)91
- [字节豆包] 由于这个气垫大小有限,所以 x 不能太大。如果 x 超过 50,气垫会自动把 x 修改为 50。 假设某人的体重为 y,只要体重 y 不超过 x ,都可以安全地落在气垫上面(受到的伤害值为0), 如果体重 y 超过 x,就会受伤,受到的伤害值为 y - x。 请你编写一个程序,计算每个人的受到的伤害值。 输入: 共两行。 第一行为两个整数,分别表示掉落人数n,以及给气垫设置的最大承受重量x。 第二行为n个整数,表示每个人的重量。 输出: n 整数,依次表示每个人受到的伤害值,相邻的数字之间用空格隔开。c++(172点数解答 | 2025-11-01 20:02:55)60
- [字节豆包] 题目描述 某测试会根据考生的分数,划分四个等级,具体规则是: 60 60 分以下:不合格 60 60 分及以上 ~ 80 80 分以下:合格 80 80 分及以上 ~ 90 90 分以下:良好 90 90 分及以上 ~ 100 100 分:优秀 输入格式 一行,一个数 a a 表示某考生的分数。 输出格式 输出对应的等级 input1 复制 59.5 output1 复制 不合格 input2 复制 89.9 output2 复制 良好 数据规模与约定 对于 100 % 100% 的数据, 0 ≤ a ≤ 100 0≤a≤100。(234点数解答 | 2025-08-31 12:55:23)193
- [字节豆包] 题目描述 某测试会根据考生的分数,划分四个等级,具体规则是: 60 60 分以下:不合格 60 60 分及以上 ~ 80 80 分以下:合格 80 80 分及以上 ~ 90 90 分以下:良好 90 90 分及以上 ~ 100 100 分:优秀 输入格式 一行,一个数 a a 表示某考生的分数。 输出格式 输出对应的等级 input1 复制 59.5 output1 复制 不合格 input2 复制 89.9 output2 复制 良好 数据规模与约定 对于 100 % 100% 的数据, 0 ≤ a ≤ 100 0≤a≤100。 语言方向:C++ 系统环境:Windows(259点数解答 | 2025-08-31 12:55:38)141
- [字节豆包] 题目描述 给定一个正整数 x x,以及另外的 n n 个正整数,请你编写程序,计算 n n 个正整数中,小于 x x 的数的总和是多少? 输入格式 共两行, 第一行依次为 x x 和 n n,数之间以一个空格间隔, 第二行依次为 n n 个正整数,数之间以一个空格间隔。 输出格式 输出一个正整数,即 n n 个数中小于 x x 的数的和。 input1 复制 10 5 1 2 3 11 10 output1 复制 6 input2 复制 29 7 9 17 35 42 28 11 2 output2 复制 67 数据规模与约定 对于 100 % 100% 的数据: 1 ≤ x ≤ 10000 1≤x≤10000, 1 ≤ n ≤ 100 1≤n≤100, 1 ≤ 1≤ 每个正整数 ≤ 10000 ≤10000。(233点数解答 | 2025-08-02 21:35:03)264
- [字节豆包] 题目描述 给定一个正整数 x x,以及另外的 n n 个正整数,请你编写程序,计算 n n 个正整数中,小于 x x 的数的总和是多少? 输入格式 共两行, 第一行依次为 x x 和 n n,数之间以一个空格间隔, 第二行依次为 n n 个正整数,数之间以一个空格间隔。 输出格式 输出一个正整数,即 n n 个数中小于 x x 的数的和。 input1 复制 10 5 1 2 3 11 10 output1 复制 6 input2 复制 29 7 9 17 35 42 28 11 2 output2 复制 67 数据规模与约定 对于 100 % 100% 的数据: 1 ≤ x ≤ 10000 1≤x≤10000, 1 ≤ n ≤ 100 1≤n≤100, 1 ≤ 1≤ 每个正整数 ≤ 10000 ≤10000。 语言方向:C++(255点数解答 | 2025-08-02 21:35:27)182