实验三

实验一

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <windows.h>
#define N 80

void print_text(int line, int col, char text[]); // 函数声明
void print_spaces(int n); // 函数声明
void print_blank_lines(int n); // 函数声明

int main() 
{
    int line, col, i;
    char text[N] = "hi, April~";
    srand(time(0)); // 以当前系统时间作为随机种子
    for(i = 1; i <= 10; ++i) {
        line = rand() % 25;
        col = rand() % 80;
        print_text(line, col, text);
        Sleep(1000); // 暂停1000ms
} 
    return 0;
} 
// 打印n个空格

void print_spaces(int n) 
{
    int i;
    for(i = 1; i <= n; ++i)
        printf(" ");
} // 打印n行空白行

void print_blank_lines(int n) {
    int i;
    for(i = 1; i <= n; ++i)
        
        printf("\n");
}
// 在第line行第col列打印一段文本
void print_text(int line, int col, char text[]) {
print_blank_lines(line-1); // 打印(line-1)行空行
print_spaces(col-1); // 打印(col-1)列空格
printf("%s", text); // 在第line行、col列输出text中字符串
}

实现了每隔随机行输出 "hi, April~"

实验二

1.

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

  

 

2.

#include <stdio.h>
#include <stdlib.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);
	system("pause");
	return 0;
}
// 函数定义
int func(int a, int b) 
{
	static int m = 0, i = 2;
	i += m + 1;
	m = i + a + b;
	return m;
}

  

 

实验3

#include <stdio.h>
long long func(int n); // 函数声明
int main() 
{
	int n;
	long long f;
	while (scanf("%d", &n) != EOF) 
	{
		f = func(n); // 函数调用
		printf("n = %d, f = %lld\n", n, f);
	}
	return 0;
}
// 函数定义
// 待补足
long long func(int n)
{
	long long s;

	if(n==1)return 1;
	else
		return (2*func(n-1)+1);

	return s;
}

  

 

实验4

 

 

 

 

 

 

 

 

实验5

#include <stdio.h>
#include<math.h>
double mypow(int x, int y); // 函数声明
int main() 
{
	int x, y;
	double ans;
	while(scanf("%d%d", &x, &y) != EOF) {
		ans = mypow(x, y); // 函数调用
		printf("%d的%d次方: %g\n\n", x, y, ans);
}
	return 0;
}

double mypow(int x,int y)
{
	int i;
	double ans=1;
	for(i=1;i<=abs(y);i++)
	{
		ans=ans*x;
	}
	if(y>0)
		return ans;
	else if(y<=0)
		return 1.0/ans;
	else
		return 1;
}

  

 实验7

#include<stdio.h>
#include <stdlib.h>
int issushu(int x)
{
	int temp=2;
	int flag;

	while(1)
	{
		if(x%temp==0)
		{flag=0;
		break;
		}
		else
			temp++;
		if(x<=temp)
		{
			flag=1;
			break;
		}
	}
	system("pause");
	return flag;
}

void main()
{
	int x,i;
	if(x%2!=0)
		printf("发生错误");
	else
	{
		for(i=1;i<(x/2+1);i++)
		{
			if(issushu(i)==1&&issushu(x-1)==1)
				printf("%d=%d+%d\n",x,i,x-i);
		}
	}
}

  实验八

#include <stdio.h>
#include <math.h>
long func(long s);
int main() 
{
	long s, t;
	printf("Enter a number: ");
	while (scanf("%ld", &s) != EOF) 
	{
		t = func(s); // 函数调用
		printf("new number is: %ld\n\n", t);
		printf("Enter a number: ");
	}
	return 0;
}

main()
{
	long s,t;
	scanf("%ld",&s);
	func(s,&t);
	printf("nwe number is:%d\n",t);
}

  

posted @ 2023-04-06 09:22  刘璎珂  阅读(8)  评论(0编辑  收藏  举报