首页 > 其他分享 >实验3

实验3

时间:2024-04-24 22:34:10浏览次数:25  
标签:int long char 实验 func printf include

#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中字符串
}

 

task2_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)
    
    system("pause");
    return 0;
}
long long fac(int n) {
    static long long p = 1;//初始化p=1只进行一次,后续不会再进行初始化(保留上一次的结果)
    printf("p=%11d\n",p);
    p = p * n;

    return p;
}

 

#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=1只进行一次,后续不会再进行初始化(保留上一次的结果)
    printf("p=%11d\n",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;
}

初始化只进行一次,后续不会再进行初始化(保留上一次的结果)
task3
#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){
    double s;
    if(n==0)
        s=0;
    else
        s=2*func(n-1)+1;
    return s;}

task4

第一种方法:

#include <stdio.h>
int func(int n, int m);

int main() {
    int n, m;

    while(scanf("%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){
    int i;
    double up=n,down=m,s;
    if(m==0)
        s=1;
    else {for(i=1;i<=m-1;i++)
    {
    up=up*(up-i);
    down=down*(down-i);
    }
    s=up/down;}
    return s;
}

第二种方法:

#include <stdio.h>
int func(int n, int m);

int main() {
    int n, m;

    while(scanf("%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(m==n||m==0)
        return 1;
    if(n<m)
        return 0;
    else {int s;s=func(n-1,m)+func(n-1,m-1);
    return s;}
}

task5

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

int main()
{
    unsigned int n;
    int s;
    while(scanf("%d",&n)!=EOF)
    {
    hanoi(n,'A','B','C');
    s=pow(2,n)-1;
    printf("一共移动了%d次\n",s); 
}
    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)
 {
     printf("%d:%c-->%c\n",n,from,to);
 }

task6

#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;
}
long func(long s){
    int m,t=1;
    long ans=0;
    while(s!=0)
    {
    m=s%10;
        if(m%2!=0)
        {
        ans=ans+t*m;
        t=t*10;
        
        }
    s=s/10;
    
    }
    return ans;
}

 

标签:int,long,char,实验,func,printf,include
From: https://www.cnblogs.com/bingmingweiai/p/18156394

相关文章

  • 软件开发与创新第二次实验———结对编程:计算出题系统
    一.结对信息2252418盛宇伟2252436董朝二.题目要求小学老师要每周给同学出300道四则运算练习题。这个程序有很多种实现方式:C/C++C#/VB.net/JavaExcelUnixShellEmacs/Powershell/VbscriptPerlPython两个运算符,100以内的数字,不需要写答案。需要检查答案是否正确,并......
  • 实验三
    实验任务一#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(){ intlin......
  • 互斥锁(实验)(不严谨)
    进程与进程的锁和线程与线程的锁是不一样的。abc三部曲pthread_mutex_tlock=PTHREAD_MUTEX_INITIALIZER;//创建一个锁pthread_mutex_lock(&lock);//上锁pthread_mutex_unlock(&lock);//开锁对于全局变量,共享数据就是临界区,需要使用锁。intticketAmount=2;//这里......
  • XMU《UNIX 系统程序设计》第二次实验报告
    一、实验内容描述实验目的掌握与文件和目录树有关的系统调用和库函数。实验要求编写程序myfind命令语法myfind<pathname>[-comp<filename>|-name<str>...]命令语义(1)myfind<pathname>的功能除了具有与程序4-7相同的功能外,还要输出在<pathname>目录子树之下,文......
  • XMU《计算机网络与通信》第三次实验报告
    一、个人信息学号:**************姓名:###二、实验目的理解TCP和UDP协议主要特点掌握socket的基本概念和工作原理,编程实现socket通信三、实验任务与结果任务1前置任务开启两个终端窗口,分别编译、运行server_example.c和client_example.c,观察它们实现的功能。......
  • 20231325 贾罗祁 实验三《Python程序设计》实验报告
    20231325贾罗祁2023-2024-2《Python程序设计》实验三报告课程:《Python程序设计》班级:2313姓名:贾罗祁学号:20231325实验教师:王志强实验日期:2024年4月17日必修/选修:公选课1.实验内容创建服务端和客户端,服务端在特定端口监听多个客户请求。客户端和服务端通过Socket套......
  • 实验二——需求分析
    一、实验题目:需求分析二、实验目的 1、掌握StarUML软件的安装; 2、掌握利用StarUML工具分析、设计、绘制用例图;3、掌握利用StarUML工具分析、设计、绘制类图;4、掌握利用StarUML工具分析、设计、绘制状态图;5、掌握利用StarUML工具分析、设计、绘制顺序图。6、掌握利用Star......
  • 实验3
    task1.c点击查看代码#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()......
  • 数字孪生系统:实验室基地园区的高效运营新引擎
    在科技飞速发展的今天,数字化转型已成为各行各业不可逆转的趋势。实验室基地园区作为科技创新的摇篮,其数字化升级更是刻不容缓。数字孪生系统作为数字化转型的得力助手,正以其独特的魅力,引领实验室基地园区走向智慧化、高效化的新纪元。 数字孪生系统就是通过数字技术将现实世界......
  • 实验3 C语言函数应用编程
    task1.c1#include<stdio.h>2#include<stdlib.h>3#include<time.h>4#include<windows.h>5#defineN8067voidprint_text(intline,intcol,chartext[]);//函数声明8voidprint_spaces(intn);//函数声明9voidpri......