实验3
最编程
2024-04-29 12:29:24
...
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, 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.c
// 利用局部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)); return 0; } // 函数定义 long long fac(int n) { static long long p = 1; p = p * n; system("pause"); 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)); return 0; } // 函数定义 long long fac(int n) { static long long p = 1; printf("p = %lld\n", p); p = p * n; system("pause"); return p; }
静态局部变量在执行过程中只会被分配一次内存空间,并且在整个运行期间其值保持不变
task2_2
#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 a,b = 1; long t = 0; for(;s != 0; ){ a = s %10; if(a%2 != 0){ t += a*b; b *=10; } s = s/10; } return t; }
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){ if(n==0) return 0; else return func(n - 1)*2 + 1; }
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 s1=1,s2=1,s3=1; int ans; int i,j,k; for(i=1;i<=n;++i) s1=s1*i; for(j=1;j<=m;++j) s2=s2*j; for(k=1;k<=(n-m);++k) s3=s3*k; ans=(double)s1/(s2*s3); return ans; }
#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) return 0; else if(m==1||m==n) return 1; else return func(n-1,m)+func(n-1,m-1); }
task5
#include<stdio.h> #include<stdlib.h> void hanoi(unsigned int n,char from,char temp,char to,int *s); void moveplate(unsigned int n,char from,char to,int *s); int main(){ unsigned int n; while(scanf("%u",&n)!=EOF){ int s=0; hanoi(n,'A','B','C',&s); printf("\n一共移动了%d次\n",s); } system("pause"); return 0; } void hanoi(unsigned int n,char from,char temp,char to,int *s){ if(n==1){ moveplate(n,from,to,s); } else { hanoi(n-1,from,to,temp,s); moveplate(n,from,to,s); hanoi(n-1,temp,from,to,s); } } void moveplate(unsigned int n,char from,char to,int *s) { printf("%u:%c-->%c\n",n,from,to); (*s)++; }
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){ long ans = 0; long a,t = 1; while(s != 0){ a = s%10; if(a%2 != 0){ ans += t*a; t*= 10; } s /=10; } return ans; }
上一篇: 简单易懂的子网划分,学会本文的子网划分就够了(实例详解)
下一篇: Java 示例 - 字符串分割
推荐阅读
-
Scala 实验 2 3
-
实验3
-
网络编程实验室 3 多人聊天室 流媒体套接字 多线程编程
-
实验3
-
Enda Wu 2022 机器学习专业课程 (I) 6.2 Logistic Regression 和第 3 周课后实验:Lab2 逻辑回归
-
什么是可用性测试?有效性(Effectiveness)-- 用户完成特定任务和实现特定目标的正确性和完整性程度;效率(Efficiency)-- 用户完成任务的正确性和完整性程度与所用资源(如时间)之比;满意度(Satisfaction)-- 用户在使用产品时的主观满意度和接受程度。 2.如何获得可用性? 可以参考以下原则:Gould、Boies 和 Lewis(1991 年)为以用户为中心的设计定义了 4 个重要原则: 早期以用户为中心:设计者应在设计过程的早期就努力了解用户的需求。 综合设计:设计的所有方面都应同步发展,而不是按顺序进行。使产品的内部设计始终与用户界面的需求保持一致。 早期和持续测试:当今唯一可行的软件测试方法是经验主义方法,即如果实际用户认为设计可行,该设计就是可行的。通过在整个开发过程中引入可用性测试,用户就有机会在产品推出之前对设计提出反馈意见。 迭代设计:大问题往往掩盖了小问题的存在。设计人员和开发人员应在整个测试过程中对设计进行迭代。 3...什么是可用性测试? 可用性测试是根据可用性标准对图形用户界面进行的系统评估。 可用性测试是衡量用户与系统(网站、软件应用程序、移动技术或任何用户操作设备)交互时的体验质量。4.如何进行可用性测试? l 实验室实验
-
数字信号处理系列实验 3--信号的频谱分析
-
数字信号处理实验 3:DTFT、频率响应和系统函数
-
实验 3:语法问题处理器
-
数字图像处理和 MATLAB 实现 实验 3 - 基本图像操作