求指定两个整数m,n之间的素数(m<n)m,n之间素数按照每个数据占6列,每行5个数据输出
时间: 2024-02-03 15:13:39 浏览: 17
以下是Python实现的代码:
```python
import math
def is_prime(num):
if num < 2:
return False
for i in range(2, int(math.sqrt(num))+1):
if num % i == 0:
return False
return True
m = int(input("请输入m:"))
n = int(input("请输入n:"))
count = 0
for i in range(m, n+1):
if is_prime(i):
print("{:6d}".format(i), end="")
count += 1
if count % 5 == 0:
print()
print()
```
运行结果如下:
```
请输入m:50
请输入n:100
53 59 61 67 71
73 79 83 89 97
```
注意,输出结果中每个数据占6列,每行5个数据输出。
相关问题
用c语言编写出求指定两个整数m,n之间的素数(m<n)m,n之间素数按照每个数据占6列,每行5个数据输出
以下是用C语言编写的求指定两个整数m,n之间的素数的程序,每行输出5个数据,每个数据占6列:
```c
#include <stdio.h>
#include <math.h>
int is_prime(int num) {
if (num <= 1) {
return 0;
}
for (int i = 2; i <= sqrt(num); i++) {
if (num % i == 0) {
return 0;
}
}
return 1;
}
int main() {
int m, n;
printf("请输入两个整数m, n(m < n): ");
scanf("%d %d", &m, &n);
int count = 0; // 记录已输出的素数个数
for (int i = m; i <= n; i++) {
if (is_prime(i)) {
printf("%6d", i);
count++;
if (count % 5 == 0) { // 每行输出5个数据
printf("\n");
}
}
}
if (count % 5 != 0) { // 如果最后一行不足5个数据,需要补齐空格
printf("\n");
}
return 0;
}
```
注意:为了判断一个数是否为素数,我们可以使用试除法。具体来说,我们从2开始,一直试除到该数的平方根,如果能被整除,那么就不是素数,否则就是素数。
c语言中求指定的两个整数m、n之间的素数,并每行5个输出
以下是实现该功能的 C 语言代码:
```c
#include <stdio.h>
int is_prime(int num) {
if (num < 2) {
return 0;
}
for (int i = 2; i * i <= num; i++) {
if (num % i == 0) {
return 0;
}
}
return 1;
}
int main() {
int m, n, count = 0;
printf("请输入两个整数m和n(m < n):\n");
scanf("%d%d", &m, &n);
for (int i = m; i <= n; i++) {
if (is_prime(i)) {
printf("%d ", i);
count++;
if (count % 5 == 0) {
printf("\n");
}
}
}
return 0;
}
```
函数 `is_prime` 用于判断一个整数是否为素数,如果是则返回 1,否则返回 0。
在主函数中,先输入两个整数 `m` 和 `n`,然后循环遍历从 `m` 到 `n` 的所有整数,如果某个整数是素数,则输出它,并且计数器 `count` 加 1。每输出 5 个素数就换行一次。