东方博宜OJ 1004 - 【入门】编程求1*2*3*...*n

题目描述:

编程求1*2*3*...*n。

输入:输入一行,只有一个整数n(1<=n<=10)

输出:输出只有一行(这意味着末尾有一个回车符号),包括1个整数。

样例

输入:5

输出:120

来源:简单循环

标签:简单循环

#include <bits/stdc++.h>
using namespace std;
int main()
{
	int n,sum=1;
	cin>>n;
	for(int i=1;i<=n;i=i+1)
		sum*=i;
	cout<<sum;
	return 0;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用二维数组来存储输入的矩阵,然后再遍历数组,将每一行的元素与对应列的元素交换位置,即可得到转置矩阵。具体代码如下: ```python m, n = map(int, input().split()) # 输入矩阵的行数和列数 matrix = [] # 定义二维数组存储矩阵 # 输入矩阵元素 for i in range(m): row = list(map(int, input().split())) matrix.append(row) # 输出转置矩阵 for j in range(n): for i in range(m): print(matrix[i][j], end=' ') print() # 换行 ``` 其中,`map(int, input().split())` 用于将输入的字符串转换为整数列表,`end=' '` 表示输出时不换行。 ### 回答2: 矩阵的转置是指将矩阵的行列互换得到的新矩阵。从键盘输入一个m * n 的矩阵,需要使用二维数组来存储矩阵的每个元素。具体步骤如下: 1.首先定义一个二维数组存储输入的矩阵: ``` int matrix[m][n]; ``` 其中,m和n是从键盘输入的参数。 2.使用循环结构从键盘读取每个元素,并存储到数组中: ``` for(int i = 0; i < m; i++){ for(int j = 0; j < n; j++){ cin >> matrix[i][j]; } } ``` 3.定义一个新的数组存储转置矩阵,即行列互换后的矩阵: ``` int transposed[m][n]; ``` 4.使用双重循环将原矩阵的每个元素放置到转置矩阵的相应位置上: ``` for(int i = 0; i < m; i++){ for(int j = 0; j < n; j++){ transposed[j][i] = matrix[i][j]; } } ``` 5.最后,使用双重循环输出转置矩阵: ``` for(int i = 0; i < n; i++){ for(int j = 0; j < m; j++){ cout << transposed[i][j] << " "; } cout << endl; } ``` 到这里,一个从键盘输入矩阵并输出转置矩阵的程序就完成了。 ### 回答3: 对于这个问题,需要先了解矩阵和转置矩阵的概念。矩阵可以理解为一个矩形网格,它由行和列组成,其中每个元素都可以用一个数字或者一个符号表示。一个$m * n$的矩阵,就是有$m$行$n$列的矩阵。转置矩阵则是将原矩阵的行和列交换,得到一个$n * m$的新矩阵。 解题思路: 1. 首先需要从键盘输入一个$m*n$的矩阵,将这个矩阵保存在一个二维数组中。 2. 然后需要进行转置操作,将原矩阵的行和列交换。 3. 最后将转置后的矩阵输出。 代码实现: ``` #include <iostream> using namespace std; int main() { int m, n; cout << "请输入矩阵的行数m和列数n(2<=m<=6, 2<=n<=6):" << endl; cin >> m >> n; int matrix[m][n]; //定义原矩阵 cout << "请输入" << m << "*" << n << "的矩阵:" << endl; for(int i = 0; i < m; i++) { for(int j = 0; j < n; j++) { cin >> matrix[i][j]; } } cout << "原矩阵为:" << endl; for(int i = 0; i < m; i++) { for(int j = 0; j < n; j++) { cout << matrix[i][j] << " "; } cout << endl; } int transposed_matrix[n][m]; //定义转置矩阵 for(int i = 0; i < n; i++) { for(int j = 0; j < m; j++) { transposed_matrix[i][j] = matrix[j][i]; //将原矩阵的第i行转置到新矩阵的第i列 } } cout << "转置后的矩阵为:" << endl; for(int i = 0; i < n; i++) { for(int j = 0; j < m; j++) { cout << transposed_matrix[i][j] << " "; } cout << endl; } return 0; } ``` 运行效果: ``` 请输入矩阵的行数m和列数n(2<=m<=6, 2<=n<=6): 3 4 请输入3*4的矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 原矩阵为: 1 2 3 4 5 6 7 8 9 10 11 12 转置后的矩阵为: 1 5 9 2 6 10 3 7 11 4 8 12 ``` 综上所述,通过以上的代码实现,就可以输入一个$m*n$的矩阵,并输出它的转置矩阵。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值