#include <stdio.h> int main() { int m, i = 1, j = 1; scanf("%d", &m); for(i = 1; i <= m; i++) { ; } printf("%d! = %d", m, j); }
时间: 2024-01-20 09:02:59 浏览: 61
这段代码中缺少循环体,导致程序无法正确计算阶乘。可以在循环体中累乘每个数,最后将结果赋值给变量j。修改后的代码如下:
```c
#include <stdio.h>
int main() {
int m, i = 1, j = 1;
scanf("%d", &m);
for(i = 1; i <= m; i++) {
j *= i;
}
printf("%d! = %d", m, j);
return 0;
}
```
这样就可以正确计算m的阶乘并输出了。
相关问题
优化#include<stdio.h> #include<math.h> int main() { long long n; long long m; while(scanf("%lld %d",&n,&m)!=EOF) { int a,i=0; int k=0; while(pow(m,i)-1<n) { i++; k++; } long long j; j=(n-pow(m,k-1))*m+1; printf("%lld \n",j); } }使其耗时变短
可以尝试以下优化:
1. 将 `pow(m, k-1)` 提取出来,避免重复计算。
2. 将 `while` 循环改为 `for` 循环,避免重复计算。
3. 使用数组存储 `pow(m, i)` 的值,避免重复计算。
优化后的代码如下:
```c
#include <stdio.h>
#include <math.h>
#define MAX_N 1000000
int main() {
long long n, m;
long long pow_m[MAX_N];
int i, k;
while (scanf("%lld %lld", &n, &m) != EOF) {
i = 0;
k = 0;
pow_m[0] = 1;
while (pow_m[k] - 1 < n) {
i++;
k++;
pow_m[k] = pow_m[k-1] * m;
}
long long j = (n - pow_m[k-1] + 1) * m + 1;
printf("%lld\n", j);
}
return 0;
}
```
这样可以避免重复计算,提高代码效率。
#include <stdio.h> #include <stdbool.h> #include <math.h> bool is-prime(int n) { if(n<=1) {return false; } for(int i=2;i<=sqrt(n);i++) { if(n%i==0) {return false; } } return turn; } int main() { int n; scanf("5d",&n); int m=n+1; while( is-prime(m)) { m+=1; } printf("%d\n",m); return 0; } 检查
这段代码有几个问题:
1. 第6行的 return turn 应该改为 return false。
2. 第13行的 scanf("5d",&n) 应该改为 scanf("%d",&n)。
3. 第17行的 is-prime 应该改为 is_prime。
修改后的代码如下:
```
#include <stdio.h>
#include <stdbool.h>
#include <math.h>
bool is_prime(int n) {
if(n<=1)
{
return false;
}
for(int i=2;i<=sqrt(n);i++)
{
if(n%i==0)
{
return false;
}
}
return false;
}
int main() {
int n;
scanf("%d",&n);
int m=n+1;
while(is_prime(m))
{
m+=1;
}
printf("%d\n",m);
return 0;
}
```
阅读全文