C语言课后作业 20 题+考研上机应用题
题目 1: 计算圆的面积
描述: 输入圆的半径,计算并输出圆的面积。
题目 2: 判断一个年份是否为闰年
描述: 输入一个年份,判断并输出该年份是否为闰年。
题目 3: 计算并输出斐波那契数列的前10个数
描述: 输出斐波那契数列的前10个数。
题目 4: 字符串长度计算
描述: 输入一个字符串,输出该字符串的长度。
题目 5: 实现冒泡排序算法
描述: 输入一个整数数组,使用冒泡排序算法对其进行排序,并输出排序后的结果。
题目 6: 计算一个整数的阶乘
描述: 输入一个正整数,输出其阶乘。
题目 7: 实现线性查找算法
描述: 在一个已排序的数组中实现线性查找算法,查找特定元素的位置。
题目 8: 计算一个数的平方根
描述: 输入一个非负实数,计算并输出其平方根。
题目 9: 实现选择排序算法
描述: 输入一个整数数组,使用选择排序算法对其进行排序,并输出排序后的结果。
题目 10: 计算一个整数的倒数
描述: 输入一个非零整数,输出其倒数。
题目 11: 实现二分查找算法
描述: 在一个已排序的数组中实现二分查找算法,查找特定元素的位置。
题目 12: 输出一个整数数组的所有元素
描述: 输入一个整数数组及其大小,输出数组的所有元素。
题目 13: 计算并输出一个整数数组的平均值
描述: 输入一个整数数组,计算并输出其平均值。
题目 14: 字符串内容替换
描述: 输入一个字符串和一个要替换的字符,将字符串中所有该字符替换为另一个字符,并输出替换后的字符串。
题目 15: 实现插入排序算法
描述: 输入一个整数数组,使用插入排序算法对其进行排序,并输出排序后的结果。
题目 16: 计算并输出一个整数的立方
描述: 输入一个整数,计算并输出其立方。
题目 17: 实现长整数相加的函数
描述: 设计一个函数,实现两个长整数的相加,并输出结果。
题目 18: 字符串翻转
描述: 输入一个字符串,输出其翻转后的字符串。
题目 19: 计算并输出一个整数的最大因子
描述: 输入一个正整数,计算并输出其最大因子。
题目 20: 实现质数生成器
描述: 输出一个范围内的所有质数。
题目 1: 计算圆的面积
#include <stdio.h>
#define PI 3.14159int main() {float radius, area;printf("Enter the radius of the circle: ");scanf("%f", &radius);area = PI * radius * radius;printf("The area of the circle is: %f\n", area);return 0;
}
题目 2: 判断一个年份是否为闰年
#include <stdio.h>int isLeapYear(int year) {if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0)return 1;return 0;
}int main() {int year;printf("Enter a year: ");scanf("%d", &year);if (isLeapYear(year)) {printf("%d is a leap year.\n", year);} else {printf("%d is not a leap year.\n", year);}return 0;
}
题目 3: 计算并输出斐波那契数列的前10个数
#include <stdio.h>int main() {int n = 10, t1 = 0, t2 = 1, nextTerm = t1 + t2;printf("Fibonacci Series: ");for (int i = 1; i <= n; ++i) {printf("%d, ", t1);nextTerm = t1 + t2;t1 = t2;t2 = nextTerm;}return 0;
}
题目 4: 字符串长度计算
#include <stdio.h>
#include <string.h>int main() {char str[100];printf("Enter a string: ");scanf("%s", str);printf("The length of the string is: %lu\n", strlen(str));return 0;
}
题目 5: 实现冒泡排序算法
#include <stdio.h>void bubbleSort(int arr[], int n) {for (int i = 0; i < n-1; i++) {for (int j = 0; j < n-i-1; j++) {if (arr[j] > arr[j+1]) {int temp = arr[j];arr[j] = arr[j+1];arr[j+1] = temp;}}}
}int main() {int n;printf("Enter the number of elements: ");scanf("%d", &n);int arr[n];printf("Enter %d elements:\n", n);for (int i = 0; i < n; i++) {scanf("%d", &arr[i]);}bubbleSort(arr, n);printf("Sorted array:\n");for (int i = 0; i < n; i++) {printf("%d\n", arr[i]);}return 0;
}
题目 6: 计算一个整数的阶乘
#include <stdio.h>long long factorial(int n) {if (n == 0)return 1;return n * factorial(n - 1);
}int main() {int num;printf("Enter a positive integer: ");scanf("%d", &num);printf("Factorial of %d is %lld.\n", num, factorial(num));return 0;
}
题目 7: 实现线性查找算法
#include <stdio.h>int linearSearch(int arr[], int n, int x) {for (int i = 0; i < n; i++) {if (arr[i] == x)return i;}return -1;
}int main() {int n;printf("Enter the number of elements: ");scanf("%d", &n);int arr[n];printf("Enter the elements: ");for (int i = 0; i < n; i++) {scanf("%d", &arr[i]);}int x;printf("Enter the element to be searched: ");scanf("%d", &x);int result = linearSearch(arr, n, x);if (result == -1)printf("Element not found.\n");elseprintf("Element found at index %d.\n", result);return 0;
}
题目 8: 计算一个数的平方根
#include <stdio.h>
#include <math.h>int main() {double num, sqrtNum;printf("Enter a number: ");scanf("%lf", &num);sqrtNum = sqrt(num);printf("Square root of %lf is %lf.\n", num, sqrtNum);return 0;
}
题目 9: 实现选择排序算法
#include <stdio.h>void selectionSort(int arr[], int n) {int i, j, min_idx, temp;for (i = 0; i < n-1; i++) {min_idx = i;for (j = i+1; j < n; j++) {if (arr[j] < arr[min_idx]) {min_idx = j;}}temp = arr[min_idx];arr[min_idx] = arr[i];arr[i] = temp;}
}int main() {int n;printf("Enter the number of elements: ");scanf("%d", &n);int arr[n];printf("Enter %d elements:\n", n);for (int i = 0; i < n; i++) {scanf("%d", &arr[i]);}selectionSort(arr, n);printf("Sorted array:\n");for (int i = 0; i < n; i++) {printf("%d\n", arr[i]);}return 0;
}
题目 10: 计算一个整数的倒数
#include <stdio.h>int main() {int num;double reciprocal;printf("Enter an integer (except 0): ");scanf("%d", &num);if (num == 0) {printf("Cannot calculate reciprocal of 0.\n");} else {reciprocal = 1.0 / num;printf("Reciprocal of %d is %f.\n", num, reciprocal);}return 0;
}
题目 11: 实现二分查找算法
#include <stdio.h>int binarySearch(int arr[], int l, int r, int x) {while (l <= r) {int m = l + (r - l) / 2;if (arr[m] == x)return m;if (arr[m] < x)l = m + 1;elser = m - 1;}return -1;
}int main() {int n, i, x, result;printf("Enter the number of elements: ");scanf("%d", &n);int arr[n];printf("Enter the elements: ");for (i = 0; i < n; i++) {scanf("%d", &arr[i]);}printf("Enter the element to be searched: ");scanf("%d", &x);result = binarySearch(arr, 0, n - 1, x);if (result == -1)printf("Element not found.\n");elseprintf("Element found at index %d.\n", result);return 0;
}
题目 12: 输出一个整数数组的所有元素
#include <stdio.h>int main() {int n, i;printf("Enter the number of elements: ");scanf("%d", &n);int arr[n];printf("Enter %d elements:\n", n);for (i = 0; i < n; i++) {scanf("%d", &arr[i]);}printf("Array elements are:\n");for (i = 0; i < n; i++) {printf("%d\n", arr[i]);}return 0;
}
题目 13: 计算并输出一个整数数组的平均值
#include <stdio.h>int main() {int n, i;long long sum = 0;printf("Enter the number of elements: ");scanf("%d", &n);int arr[n];printf("Enter %d elements:\n", n);for (i = 0; i < n; i++) {scanf("%d", &arr[i]);sum += arr[i];}double average = (double)sum / n;printf("Average is: %f\n", average);return 0;
}
题目 14: 字符串内容替换
#include <stdio.h>
#include <string.h>int main() {char str[100], ch1, ch2;printf("Enter the string: ");scanf("%s", str);printf("Enter the character to be replaced: ");scanf(" %c", &ch1);printf("Enter the replacement character: ");scanf(" %c", &ch2);for (int i = 0; i < strlen(str); i++) {if (str[i] == ch1) {str[i] = ch2;}}printf("Modified string is: %s\n", str);return 0;
}
题目 15: 实现插入排序算法
#include <stdio.h>void insertionSort(int arr[], int n) {int i, key, j;for (i = 1; i < n; i++) {key = arr[i];j = i - 1;while (j >= 0 && arr[j] > key) {arr[j + 1] = arr[j];j = j - 1;}arr[j + 1] = key;}
}int main() {int n;printf("Enter the number of elements: ");scanf("%d", &n);int arr[n];printf("Enter %d elements:\n", n);for (int i = 0; i < n; i++) {scanf("%d", &arr[i]);}insertionSort(arr, n);printf("Sorted array:\n");for (int i = 0; i < n; i++) {printf("%d\n", arr[i]);}return 0;
}
题目 16: 计算并输出一个整数的立方
#include <stdio.h>int main() {int num;printf("Enter an integer: ");scanf("%d", &num);int cube = num * num * num;printf("Cube of %d is %d.\n", num, cube);return 0;
}
题目 17: 实现长整数相加的函数
#include <stdio.h>
#include <string.h>void add(long long int a[], long long int b[], int size) {int carry = 0, sum, i;long long int c[size];for (i = 0; i < size; i++) {sum = a[i] + b[i] + carry;carry = sum / 10;c[i] = sum % 10;}for (i = size - 1; i >= 0; i--) {printf("%lld", c[i]);}printf("\n");
}int main() {long long int a[] = {0, 0, 0}; // Initialize to the length requiredlong long int b[] = {0, 0, 0};int size;printf("Enter the size of the integers: ");scanf("%d", &size);printf("Enter the first integer: ");for (int i = 0; i < size; i++) {scanf("%lld", &a[i]);}printf("Enter the second integer: ");for (int i = 0; i < size; i++) {scanf("%lld", &b[i]);}add(a, b, size);return 0;
}
题目 18: 字符串翻转
#include <stdio.h>
#include <string.h>int main() {char str[100];printf("Enter a string: ");scanf("%s", str);int len = strlen(str);for (int i = 0; i < len / 2; i++) {char temp = str[i];str[i] = str[len - i - 1];str[len - i - 1] = temp;}printf("Reversed string is: %s\n", str);return 0;
}
题目 19: 计算并输出一个整数的最大因子
#include <stdio.h>int maxFactor(int num) {for (int i = num / 2; i >= 1; i--) {if (num % i == 0)return i;}return 1; // Since 1 is the minimum factor other than the number itself
}int main() {int num;printf("Enter an integer: ");scanf("%d", &num);int maxFactorValue = maxFactor(num);printf("The largest factor of %d is %d.\n", num, maxFactorValue);return 0;
}
题目 20: 实现质数生成器
#include <stdio.h>int isPrime(int num) {if (num <= 1)return 0;for (int i = 2; i * i <= num; i++) {if (num % i == 0)return 0;}return 1;
}void printPrimes(int start, int end) {printf("Prime numbers between %d and %d are:\n", start, end);for (int i = start; i <= end; i++) {if (isPrime(i))printf("%d ", i);}printf("\n");
}int main() {int start, end;printf("Enter the range (start end): ");scanf("%d %d", &start, &end);printPrimes(start, end);return 0;
}
相关文章:
C语言课后作业 20 题+考研上机应用题
题目 1: 计算圆的面积 描述: 输入圆的半径,计算并输出圆的面积。 题目 2: 判断一个年份是否为闰年 描述: 输入一个年份,判断并输出该年份是否为闰年。 题目 3: 计算并输出斐波那契数列的前10个数 描述: 输出斐波那…...
macOS上基于httpd-dav搭建WebDav服务
文章目录 配置 Apache httpd修改 ServerName启动验证 httpd 服务启用 Dav 扩展服务配置 配置 httpd 扩展 Dav 服务设置共享目录文件夹配置 DavLockDB 目录创建 WebDAV 访客用户 httpd-dav.conf 主要改动部分BasicDigest共享多个目录 授予 httpd 完全磁盘访问权限验证更新配置重…...
Java-设计模式-单例模式
单例模式 从单例加载的时机区分,有懒汉模式/饥饿模式。 从实现方式区分有双重检查模式,内部类模式/Enum模式/Map模式等。在《Effective Java》中,作者提出利用Enum时实现单例模式的最佳实践。 内容概要 实现单例模式的几个关键点 利用Enu…...
图片html5提供的懒加载与vue-lazyload的区别
原生HTML lazy loading特性 <img src"/images/ocean.jpeg" alt"Ocean" loading"lazy"> loading"lazy" 是HTML5的一个原生特性,它允许浏览器延迟加载图片直至图片距离视口很近或者即将进入视口时。这是一种由浏览器…...
golang 根据某个特定字段对结构体的顺序进行排序
文章目录 方法一方法二方法三 在Go语言中,我们可以使用 sort.Slice() 函数对结构体进行排序。假设你有一个结构体,并且希望根据其中的某个字段进行排序,你可以使用自定义的排序函数。 方法一 下面是一个示例代码,假设有一个包含…...
React Router 参数使用详解
React Router 参数使用详解 React Router 是 React 中用于处理路由的常用库,它提供了丰富的功能来管理应用程序的导航和路由状态。在 React Router 中,我们经常需要使用不同类型的参数来处理路由信息,包括 params 参数、search 参数和 state…...
Vue中$set用法解析
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,视图将会产生“响应”,即匹配更新为新的值,但是遇到以下情况不会进行数据的双向绑定。 当你利用索引直接改…...
进制,码制及其表示范围
一 进制 1 常见的进制及其简写 十进制(Dec)二进制(Binary)十六进制(Hex)八进制(Octal) 2 进制之间的相互转换 二 码制 1 常用的码制 三 各码制在定点整数时表示的范围 个人推导…...
钡铼技术R40工业4G路由器加速推进农田水利设施智能化
钡铼技术R40工业4G路由器作为一种先进的通信设备,正在被广泛应用于各行各业,其中包括农田水利设施的智能化改造。通过结合钡铼技术R40工业4G路由器,农田水利设施可以实现更高效的管理和运营,提升农田灌溉、排水等工作效率…...
基于龙芯2k1000 mips架构ddr调试心得(一)
1、基础知识 DDR2的I/O频率是DDR的2倍,也就是266、333、400MHz。 DDR3传输速率介于 800~1600 MT/s之间 DDR4的传输速率目前可达2133~3200 MT/s 2k1000内存:板载2GB DDR3 ,可选4GB 使用龙芯芯片最好用他们自己的Bo…...
智能合约语言(eDSL)—— 使用rust实现eDSL的原理
为理解rust变成eDSL的实现原理,我们需要简单了解元编程与宏的概念,元编程被描述成一种计算机程序可以将代码看待成数据的能力,使用元编程技术编写的程序能够像普通程序在运行时更新、替换变量那样操作更新、替换代码。宏在 Rust 语言中是一种功能&#x…...
敏捷开发——elementUI/Vue使用/服务器部署
1. 创建vue项目 2. 安装element-ui组件库 npm i -S element-ui或 npm install element-ui3. 在main.js中导入element-ui组件 import ElementUI from element-ui import element-ui/lib/theme-chalk/index.css Vue.use(ElementUI)element-ui 组件库地址:Element …...
uniapp 使用sqlite时无法读取到db文件中的数据
问题 {“code”:-1404,“message”:“android.database.sqlite.SQLiteException: no such table: user (Sqlite code 1): , while compiling: select * from user, (OS error - 2:No such file or directory),http://ask.dcloud.net.cn/article/282”} at pages/index/index.vu…...
Linux 网络接口管理
为了更深入的了解linux系统,为此做出网络接口管理的知识总结。看起来麻烦,其实一点都不难,相信多看多了解总会是没错的!❤️❤️ 一起加油吧!✨✨🎉🎉 文章目录 前言一、网络配置的文件介绍二、…...
【设计模式】Java 设计模式之模板策略模式(Strategy)
策略模式详解:模式结构、实现与应用场景 一、策略模式概述 策略模式是一种行为设计模式,它使得算法可以独立于使用它的客户端变化。策略模式使得算法可以在运行时切换,从而增强了系统的灵活性和可维护性。在策略模式中,我们定义…...
SpringBoot项目前端Vue访问后端(图片静态资源) 配置
静态资源配置 Configuration public class WebMvcConfig extends WebMvcConfigurationSupport {Value("${file.save-path}")private String fileSavePath;Overrideprotected void addResourceHandlers(ResourceHandlerRegistry registry) {//映射本地文件夹registry…...
colab中数据集保存到drive与取出的方法
from google.colab import drive drive.mount(/content/drive) 一、下载数据集 from datasets import load_dataset max_length 32 # Maximum length of the captions in tokens coco_dataset_ratio 50 # 50% of the COCO2014 dataset# Load the COCO2014 dataset for tr…...
React 应该如何学习?
学习 React 是现代 Web 前端开发中的重要一步,因为它是一个流行且强大的 JavaScript 库,用于构建用户界面。React 的学习过程需要掌握一系列的概念、技术和最佳实践。 1. 基础知识 1.1 HTML、CSS 和 JavaScript React 本质上是一个 JavaScript 库&…...
跨平台无缝操作:ShareMouse让多电脑协同更高效
ShareMouse是一款功能强大的鼠标和键盘共享软件,它支持多台计算机之间的无缝连接,让用户能够通过一套键鼠设备轻松控制多台电脑,提高工作效率。此外,ShareMouse还具备剪贴板共享、文件拖放等功能,实现不同计算机间的便…...
Vue使用pandoc-wasm进行各格式转换
前端使用pandoc-wasm的问题和建议 docx转md npm install --save pandoc-wasmimport { Pandoc } from "pandoc-wasm";const pandoc new Pandoc()pandoc.init().then(async (pandoc) > {const result await pandoc.run({text: "Some input text",opti…...
SpringBoot-17-MyBatis动态SQL标签之常用标签
文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…...
从零实现富文本编辑器#5-编辑器选区模型的状态结构表达
先前我们总结了浏览器选区模型的交互策略,并且实现了基本的选区操作,还调研了自绘选区的实现。那么相对的,我们还需要设计编辑器的选区表达,也可以称为模型选区。编辑器中应用变更时的操作范围,就是以模型选区为基准来…...
Java如何权衡是使用无序的数组还是有序的数组
在 Java 中,选择有序数组还是无序数组取决于具体场景的性能需求与操作特点。以下是关键权衡因素及决策指南: ⚖️ 核心权衡维度 维度有序数组无序数组查询性能二分查找 O(log n) ✅线性扫描 O(n) ❌插入/删除需移位维护顺序 O(n) ❌直接操作尾部 O(1) ✅内存开销与无序数组相…...
定时器任务——若依源码分析
分析util包下面的工具类schedule utils: ScheduleUtils 是若依中用于与 Quartz 框架交互的工具类,封装了定时任务的 创建、更新、暂停、删除等核心逻辑。 createScheduleJob createScheduleJob 用于将任务注册到 Quartz,先构建任务的 JobD…...
Vue2 第一节_Vue2上手_插值表达式{{}}_访问数据和修改数据_Vue开发者工具
文章目录 1.Vue2上手-如何创建一个Vue实例,进行初始化渲染2. 插值表达式{{}}3. 访问数据和修改数据4. vue响应式5. Vue开发者工具--方便调试 1.Vue2上手-如何创建一个Vue实例,进行初始化渲染 准备容器引包创建Vue实例 new Vue()指定配置项 ->渲染数据 准备一个容器,例如: …...
在四层代理中还原真实客户端ngx_stream_realip_module
一、模块原理与价值 PROXY Protocol 回溯 第三方负载均衡(如 HAProxy、AWS NLB、阿里 SLB)发起上游连接时,将真实客户端 IP/Port 写入 PROXY Protocol v1/v2 头。Stream 层接收到头部后,ngx_stream_realip_module 从中提取原始信息…...
TRS收益互换:跨境资本流动的金融创新工具与系统化解决方案
一、TRS收益互换的本质与业务逻辑 (一)概念解析 TRS(Total Return Swap)收益互换是一种金融衍生工具,指交易双方约定在未来一定期限内,基于特定资产或指数的表现进行现金流交换的协议。其核心特征包括&am…...
反射获取方法和属性
Java反射获取方法 在Java中,反射(Reflection)是一种强大的机制,允许程序在运行时访问和操作类的内部属性和方法。通过反射,可以动态地创建对象、调用方法、改变属性值,这在很多Java框架中如Spring和Hiberna…...
Spring AI 入门:Java 开发者的生成式 AI 实践之路
一、Spring AI 简介 在人工智能技术快速迭代的今天,Spring AI 作为 Spring 生态系统的新生力量,正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务(如 OpenAI、Anthropic)的无缝对接&…...
管理学院权限管理系统开发总结
文章目录 🎓 管理学院权限管理系统开发总结 - 现代化Web应用实践之路📝 项目概述🏗️ 技术架构设计后端技术栈前端技术栈 💡 核心功能特性1. 用户管理模块2. 权限管理系统3. 统计报表功能4. 用户体验优化 🗄️ 数据库设…...
