首页 > 其他分享 >实验3

实验3

时间:2023-03-31 22:33:49浏览次数:30  
标签:return int long 实验 func printf include

Task1

<实验结论>

#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
	}
	system("pause");
	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中字符串
}

**程序功能:

   在输出区任意位置随机打印出指定字符

 

 

 

Task2

<实验结论>

 

task2_1

// 利用局部static变量的特性,计算阶乘
#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;
	p = p * n;
	return p;
}

**增加一行源代码后

// 利用局部static变量的特性,计算阶乘
#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 = %2lld  ",p);
	p = p * n;
	return p;
}

 

task2_2

// 练习:局部static变量特性
#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;
}

**实验运行结果与理论分析结果一致

 

 

<实验总结>

局部static变量特性:

 1、变量只能被一个函数所使用,若在其它函数中用会被视为非法

 2、变量值的存储为静态存储,函数退出后,变量依然存在

 

 

 

Task3

<实验结论>

#include <stdio.h>
#include <stdlib.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);
	}
	system("pause");
	return 0;
}

// 函数定义
long long func(int n)
{
	while(n >= 0){
		if(n == 0)
			return 0;
		else
			return 2*func(n-1) + 1;
	}
}

 

 

 

Task4

<实验结论>

#include <stdio.h>
#include <stdlib.h>

int func(int n,int m);

int main()
{
	int n,m;

	while(scanf("%d%d",&n,&m)!=0)
		printf("n = %d,m = %d,ans = %d\n",n,m,func(n,m));

	system("pause");
	return 0;
}

int func(int n,int m)
{
	if(n == m || m == 0)
		return 1;
	else if(n < m)
		return 0;
	else
		return func(n-1,m) + func(n-1,m-1);
}

 

 

 

Task5

<实验结论>

 

task5_1

#include <stdio.h>
#include <stdlib.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);
	}
	system("pause");
	return 0;
}
// 函数定义
double mypow(int x,int y)
{
	int i;
	double ans=1.0;

	if(y > 0){
		for(i=0;i<y;i++)
			ans *= double(x);
		return ans;
	}
	if(y == 0)
		return 1;
	if(y < 0){
		for(i=0;i<(-y);i++)
			ans *= double(x);
		return 1 / ans;
	}
}

 

task5_2

#include <stdio.h>
#include <stdlib.h>

double mypow(double 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);
	}
	system("pause");
	return 0;
}
// 函数定义
double mypow(double x,int y)
{
	if(y > 0)
		return x * mypow(x,y-1);
	if(y == 0)
		return 1;
	if(y < 0)
		return 1 / x * mypow(x,y+1);
}	

 

 

 

Task6

<实验结论>

#include<stdio.h>
#include<stdlib.h>
void hanoi(unsigned int n, char from, char temp, char to);
void moveplate(unsigned int n, char from, char to);

int tot;

int main() {
    unsigned int n;
    while (scanf_s("%u", &n) != EOF) {
        tot = 0;
        hanoi(n, 'A', 'B', 'C');
        printf("一共移动了%d次\n", tot);}
    system("pause");
    return 0;
}

void hanoi(unsigned int n, char from, char temp, char to) {
    if (n == 1) {
        moveplate(n, from, to);
    }
    else {
        hanoi(n - 1, from, to, temp);
        moveplate(n, from, to);
        hanoi(n - 1, temp, from, to);
    }
}

void moveplate(unsigned int n, char from, char to) {
    tot ++;
    printf("%u:%c-->%c\n", n, from, to);
}

 

 

 

Task7

<实验结论>

#include<stdio.h>
#include<stdlib.h>

int is_prime(int x);

int main() {
    int i, n;
    while (scanf_s("%d", &n) != EOF) {
        for (i = 2; i <= n; i++) {
            if (!is_prime(i) || !is_prime(n - i))continue;
            printf("%d = %d + %d\n", n, i, n - i);
            break;
        }
    }
	system("pause");
    return 0;
}

int is_prime(int x) {
    int i;
    for (i = 2; i *i<= x; i++) {
        if (x % i == 0) {
            return 0;}
        else { 
            return 1; }
    }
}

 

 

 

Task8

<实验结论>

#include <stdio.h>
#include <math.h>
#include<stdlib.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: ");
    }
    system("pause");
    return 0;
}
long func(long s)
{
    long ans,z=0,q=0,j;

    for(;s!=0;){
        ans = s % 10;
        s = s / 10;
        if(ans%2 != 0)
          z = z*10 +ans;    
    }
    for(;z!=0;){
        j = z % 10;
        z = z/10;
        q = q*10 + j;
    }
    return q;
}

标签:return,int,long,实验,func,printf,include
From: https://www.cnblogs.com/550w/p/17270571.html

相关文章

  • 实验3
    实验1实验代码#include<stdio.h>#include<stdlib.h>#include<time.h>#include<windows.h>#defineN80voidprint_text(intline,intcol,chartext[]);voidprint_spaces(intn);voidprint_blank_lines(intn);intmain(){ intline,col,......
  • 202031607330-杨雯丽 实验一 软件工程准备—认识软件工程
    实验一:软件工程准备项目内容班级课程博客链接20级卓越班此次作业链接实验一软件工程准备我的课程学习目标(1)学习博客园软件开发者学习社区使用技巧和经验。(2)了解Github的基本操作。本次作业在哪些方面帮我实现学习目标(1)了解与掌握了博客园的基本使用(2)熟练了......
  • 202031607334-贾小萌 实验一 软件工程准备 初步认识软件工程
    项目内容班级博客链接20级卓越班本次作业要求链接实验一软件工程准备我的课程学习目标学习博客园软件开发者学习社区使用技巧和经验;了解Github基本操作本次作业在哪方面帮我实现学习目标初步了解博客园软件和Github的基本操作;初步认识软件工程实验内容......
  • 202031705119-张倩 实验一 软件工程准备——初步认识软件工程
    一.博文开头项目内容班级博客链接2023春软件工程(2020级计算机科学与技术)本次作业要求链接实验一软件工程准备我的课程学习目标1.学会使用博客园的基本功能2.学会使用Github的基本功能3.阅读《现代软件工程——构建之法》并解决提出的问题本次作业在哪些......
  • 实验二
    task11x="nbaFIFA"2print(x.upper())3print(x.lower())4print(x.swapcase())5print()6x="abc"7print(x.center(10,'*'))8print(x.ljust(10,'*'))9print(x.rjust(10,'*'))10x="123&quo......
  • 实验三
    实验任务一程序源码:#include<stdio.h>#include<stdlib.h>#include<time.h>#include<windows.h>#defineN80voidprint_text(intline,intcol,chartext[]);//函数声明voidprint_spaces(intn);//函数声明voidprint_blank_lines(intn);//函数声明intmai......
  • 拼多多的三农新实验:向下扎根,向上入云
    技术能带来红利,也能扩大鸿沟。当ChatGPT引发人们对生产力大解放憧憬的同时,也带给人们担忧:哪些职业将受到冲击?是否会有更多人失业?事实上,每一轮重大技术革新中,都有行业、企业,甚至个体,因应用技术的时间先后、程度深浅不一,而拉开差距。幸运的是,总有一些人在努力磨平这种技术鸿沟。在......
  • 202031607332-阿卜杜热合曼·麦麦提艾萨 实验一 软件工程准备—对课程的初步认识
    项目内容班级博客链接2023年春软件工程(2020级计算机科学与技术本次作业要求链接实验一软件工程准备我的课程学习目标1.学习博客园软件开发者学习社区使用技巧和经验2.了解Github的基本操作本次作业在哪些方面帮我实现学习目标学习了博客园使用技巧,Github的......
  • 网络对抗实验四 恶意代码分析
    目录[实践内容](#1)(id="1")#实践内容(一)系统运行监控1.使用如计划任务,每隔一分钟记录自己的电脑有哪些程序在联网,连接的外部IP是哪里。运行一段时间并分析该文件,综述一下分析结果。目标就是找出所有连网的程序,连了哪里,大约干了什么(不抓包的情况下只能猜),你觉得它这么干合适不。......
  • 实验3
    实验任务1程序代码:#include<stdio.h>#include<stdlib.h>#include<time.h>#include<Windows.h>#defineN80voidprint_text(intline,intcol,chartext[]);//函数声明voidprint_spaces(intn);//函数声明voidprint_blank_lines(intn);//函数声明int......