首页 > 编程语言 >实验三 函数应用编程

实验三 函数应用编程

时间:2022-11-03 01:22:31浏览次数:53  
标签:return 函数 int 编程 long 实验 func printf include

实验任务一

task1.c

#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,November~";

srand(time(0));

for (i = 1;i <= 10;i++) {
line = rand() % 25;
col = rand() % 80;
print_text(line, col, text);
Sleep(1000);
}
return 0;
}

void print_spaces(int n) {
int i;
for (i = 1;i <= n;++i)
printf(" ");

}
void print_blank_lines(int n) {

int i;
for (i = 1;i <= n;++i)
printf("\n");
}
void print_text(int line, int col, char text[]) {
print_blank_lines(line - 1);
print_spaces(col - 1);
printf("%s", text);
}

程序功能:在屏幕上输出“hi,November~”做出动画效果

实验任务二

task2_1.c

#include <stdio.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));
    return 0;
}
long long fac(int n) {
    static long long p = 1;
    p = p * n;
    return p;
}

#include <stdio.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));
    return 0;
}
long long fac(int n) {
    static long long p = 1;
    printf("p = %lld\n", p);
    p = p * n;
    return p;
}

task2_2.c

#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;
}

实验运行结果与我理论分析得到的结果一致

局部static变量在函数内作定义说明,作用仅限于函数内部,保存变量被修改后的值,且变量不会在下一次的循环中被初始化

实验任务三

task3.c

 

#include <stdio.h>
long long func(int n);
int main() {
    int n;
    long long f;
    while (scanf_s("%d", &n) != EOF);
    {
        f = func(n);
        printf("n=%d,f=%lld\n", n, f);
    }
    return 0;
}
long long func(int n){
    int result ;
    if (n == 0) return 0;
    else return 2 * func(n - 1) + 1;
    
}

实验任务四

#include <stdio.h>
int func(int n, int m);
int main() {
    int n, m;
    while (scanf_s("%d%d", &n, &m) != EOF)
        printf("n=%d,m=%d,ans=%d\n", n, m, func(n, m));
    return 0;
}
int func(int n, int m) {
    if (n < m)return 0;
    if (n == m || n == 1 || m == 0)return 1;
    else return func(n - 1, m) + func(n - 1, m - 1);
}

实验任务五

#include <stdio.h>
int mul(int n, int m);
int main() {
    int n, m;
    while (scanf_s("%d%d", &n, &m) != EOF)
        printf("%d*%d=%d\n", n, m, mul(n, m));
    return 0;
}
int mul(int n, int m) {
    if (m==0||n==0)return 0;
    else return m+mul(n -1, m);
}

实验任务六

#include <stdio.h>
#include<stdlib.h>
void hanoi(unsigned int n, char ftom, char temp, char to);
void moveplate(unsigned int n, char from, char to);
int count = 0;
int main() {
    unsigned int n;
    while (scanf_s("%d", &n) != EOF) {
        hanoi(n, 'A', 'B', 'C');
        printf("一共移动了%d次\n", count);
        count=0;
    }
    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)
{
    printf("%u:%c --> %c\n",n, from, to);
    count++;
}

实验任务七

#include <stdio.h>
int is_prime(int n);
int main()
{    int num, f;
    int stop = 0;
    int i = 2;
    while (i < 20)
    {   i += 2;
        for (int k = 2; k < i;k++)
        {   num = i - k;
            f = is_prime(num);
            if (f)
            {printf("%d = %d + %d\n", i, k, num);
             stop = 1;}
            if (stop) break; }
        stop = 0;}
 return 0;
}
int is_prime(int n)
{if (n == 1) return 0;

    for (int i = 2;i < n;i++)
    {
        int stop = 0;
        if (n % i == 0)
        {return 0;
         stop = 1;
        }
        if (n == 2 || (n % i != 0 && i == n - 1)) return 1;
        if (stop) break;}
}

实验任务八

#include <stdio.h>
#include <math.h>

long fun(long s);

int main() {
    long s, t;

    printf("Enter a number: ");

    while (scanf("%ld", &s) != EOF)
    {
        t = fun(s);
        printf("new number is: %ld\n\n", t);
        printf("Enter a number: ");
    }

    return 0;
}

long fun(long s)
{
    int n;
    int i = 0;
    int count = 0;
    while (s != 0)
    {
        n = s % 10;
        if (n % 2 != 0)
        {
           i = n * pow(10, count) + i;
            count++;
        }
        s = s / 10;
    }
    return i;
}

 

标签:return,函数,int,编程,long,实验,func,printf,include
From: https://www.cnblogs.com/u3004105/p/16852924.html

相关文章

  • 实验7:基于REST API的SDN北向应用实践
    (一)基本要求编写Python程序,调用OpenDaylight的北向接口实现以下功能(1)利用Mininet平台搭建下图所示网络拓扑,并连接OpenDaylight;(2)下发指令删除s1上的流表数据。创建odl......
  • 实验7:基于REST API的SDN北向应用实践
    一、实验目的能够编写程序调用OpenDaylightRESTAPI实现特定网络功能;能够编写程序调用RyuRESTAPI实现特定网络功能。二、实验环境下载虚拟机软件OracleVisualBo......
  • Pthread 并发编程(一)——深入剖析线程基本元素和状态
    Pthread并发编程(一)——深入剖析线程基本元素和状态前言在本篇文章当中讲主要给大家介绍pthread并发编程当中关于线程的基础概念,并且深入剖析进程的相关属性和设置,以及......
  • C语言 模拟实现字符串函数 看着一篇够了
    C语言模拟实现字符串操作的库函数求字符串长度strlen思路1.如果碰到\0就代表字符串已经到了末尾size_tmy_strlen(constchar*str){ assert(str!=NULL); //......
  • 字符操作函数
    核心都是将字符串在传参时,由于形参int的限制转换为了每个字符对应的ASCII码然后进行判断和转换字符的判断分类函数返回值是该分类返回非0的正数,否则返回0 //字......
  • 实验3 C语言控制语句应用编程
    #include<stdio.h>#include<stdlib.h>#include<time.h>#include<windows.h>#defineN80voidprint_text(intline,intcol,chartext[]);voidprint_spaces......
  • 实验7:基于REST API的SDN北向应用实践
    一、实验目的能够编写程序调用OpenDaylightRESTAPI实现特定网络功能;能够编写程序调用RyuRESTAPI实现特定网络功能。二、实验环境下载虚拟机软件OracleVisualBox或......
  • 实验七
    1.编写Python程序,调用OpenDaylight的北向接口实现以下功能(1)利用Mininet平台搭建下图所示网络拓扑,并连接OpenDaylight;搭建拓扑:连接opendaylight:(2)下发指令删除s1上的......
  • piapiapia(代码审计、反序列化逃逸、函数绕过)
    wp进入题目,一个登录框,F12和源代码没有看到提示,robots.txt也没有东西。于是试一试访问www.zip,没想到有源码,省了扫描目录的时间。里面有6个php文件,使用Seay审计代码,简单看......
  • 并发编程之锁
    什么是Lock锁是一种工具,用于控制对共享资源的访问。Lock和synchronized作用相同,都可以实现线程安全的目的。Lock不会像synchronized一样在异常时自动释放锁。L......