实验三
实验一
#include<stdio.h>
long long fac(int n); // 函数声明
int main()
{
int i, n;
printf("Enter n: ");
scanf_s("%d", &n);
for (i = 1; i <= n; ++i)
printf("%d! = %lld\n", i, fac(i));
return 0;
}
// 函数定义
long long fac(int n)
{
static long long p = 1;
printf_s("p=%d\n", p);
p = p * n;
return p;
}

static:增长局部变量p的生命周期,将上一次所得的p的值保存下来。
#include <stdio.h>
int func(int, int); // 函数声明
int main()
{
int k = 4, m = 1, p1, p2;
p1 = func(k, m); // 函数调用
p2 = func(k, m); // 函数调用
printf("%d,%d\n", p1, p2);
return 0;
}
// 函数定义
int func(int a, int b)
{
static int m = 0, i = 2;
i += m + 1;
m = i + a + b;
return (m);
}

8,17 符合
实验二
#include <stdio.h>
void printSymbol(int n, char symbol); // 函数声明
int main()
{
int n;
char symbol;
while (scanf_s("%d %c", &n, &symbol) != EOF)
{
printSymbol(n, symbol); // 函数调用
printf_s("\n");
}
return 0;
}
void printSymbol(int n, char symbol)
{
int i = 0;
for (i = 0; i < n; i++)
printf_s("%c",symbol);

#include <stdio.h>
void printSymbol(int n, char symbol); // 函数声明
int main()
{
int n;
char symbol;
while (scanf_s("%d %c", &n, &symbol) != EOF)
{
printSymbol(n, symbol); // 函数调用
printf_s("\n");
}
return 0;
}
void printSymbol(int n, char symbol)
{
if (n == 1)
printf_s("%c", symbol);
else
{
printSymbol(n - 1, symbol);
printf_s("%c", symbol);
}
}

实验3:
#include <stdio.h>
long long fun(int n); // 函数声明
int main()
{
int n;
long long f;
while (scanf_s("%d", &n) != EOF)
{
f = fun(n); // 函数调用
printf_s("n = %d, f = %lld\n", n, f);
}
return 0;
}
long long fun(int n)
{
if (n == 0)
return 0;
else if (n == 1)
return 1;
else
{
return 2*fun(n - 1) + 1;
}
}

实验四:
#include<stdio.h>
int isprime(int n);
int main()
{
int a, b, c = 0;
for (a = 101; a <= 200; a++)
{
b= isprime(a);
if (b == 1)
continue;
else {
printf("%4d", a);
c++;
}
}
printf("\n");
printf("101~200之间一共有%d个非素数", c);
return 0;
}
int isprime(int n)
{
int i, s;
for (i = 2; i <= n; i++) {
s = n % i;
if (s == 0)
break;
}
if (i == n)
return 1;
else
return 0;
}

实验五:
#include<stdio.h>
long fun(long s);
int main()
{
long s, t;
printf_s("Enter a number:");
while (scanf_s("%ld", &s) != EOF)
{
t = fun(s);
printf_s("new number is:%ld\n\n", t);
printf_s("Enter a number:");
}
return 0;
}
long fun(long s)
{
int num, result = 0, j = 1;
while (s > 0)
{
num = s % 10;
if (num % 2 == 1)
{
result = result + j * num;
j = j * 10;
}
s = s / 10;
}
return result;
}
实验六:
int main()
{
int n;
double s;
printf("Enter n(1~10):");
while (scanf_s("%d", &n) != EOF)
{
s = fun(n);
printf_s("n=%d,s=%f\n\n", n, s);
printf_s("Enter n(1~10):");
}
return 0;
}
double fun(int n)
{
int i, k = 1, j = 1;
double result = 0;
double a;
for (i = 1; i <= n; i++)
{
k = k * i;
a = 1.0 / k;
result = result + j * a;
j *= -1;
}
return result;


浙公网安备 33010602011771号