使用c++ 输入两个正整数n(0<n<10)和m(0<m<10),绘制一个n行m列,由数字组成的矩形。
时间: 2023-06-12 14:06:12 浏览: 188
以下是使用 C 语言实现的代码:
```c
#include <stdio.h>
int main() {
int n, m;
printf("请输入两个正整数n和m(0<n<10,0<m<10):");
scanf("%d %d", &n, &m);
// 绘制矩形
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= m; j++) {
printf("%d", i*j);
}
printf("\n");
}
return 0;
}
```
解释一下代码:
首先,使用 `scanf()` 函数从用户输入中获取两个正整数 `n` 和 `m`,分别表示矩形的行数和列数。
接着,使用两个嵌套的 `for` 循环来绘制矩形。外层循环控制行数,内层循环控制列数。在内层循环中,使用 `%d` 格式化符来输出当前行数和列数的积。
最后,使用 `return 0` 语句结束程序。
相关问题
c++输入两个正整数n(0<n<10)和m(0<m<10),绘制一个n行m列,由数字组成的矩形。矩形的每行从1开始,到m结束。
以下是一个C++程序,用于根据用户输入的正整数n和m绘制一个由数字组成的矩形:
```cpp
#include <iostream>
int main() {
int n, m;
// 输入行数和列数
std::cout << "请输入行数n (0 < n < 10): ";
std::cin >> n;
std::cout << "请输入列数m (0 < m < 10): ";
std::cin >> m;
// 绘制矩形
for (int i = 0; i < n; i++) {
for (int j = 1; j <= m; j++) {
std::cout << j;
}
std::cout << std::endl;
}
return 0;
}
```
这个程序通过使用嵌套的for循环,根据用户输入的行数n和列数m,绘制了一个由数字组成的矩形。外层循环控制行数,内层循环控制列数,在每一行的循环中输出从1到m的数字,然后换行。
请注意,这里假设用户输入的n和m确实满足要求(即0 < n < 10和0 < m < 10),没有做输入验证。
希望这个程序能满足你的需求!如果有任何问题,请随时提问。
C++输入两个正整数m和n求其最大公约数和最小公倍数
以下是C++代码:
```
#include <iostream>
using namespace std;
int gcd(int m, int n) {
if(n == 0) return m;
return gcd(n, m % n);
}
int lcm(int m, int n) {
return m / gcd(m, n) * n;
}
int main() {
int m, n;
cout << "请输入两个正整数m和n:" << endl;
cin >> m >> n;
cout << "最大公约数为:" << gcd(m, n) << endl;
cout << "最小公倍数为:" << lcm(m, n) << endl;
return 0;
}
```
首先定义了 `gcd` 函数来计算最大公约数,使用递归的方式实现辗转相除法。然后定义 `lcm` 函数来计算最小公倍数,直接使用公式:两数之积等于它们的最大公约数和最小公倍数的乘积。最后在 `main` 函数中读入两个正整数,分别输出最大公约数和最小公倍数即可。