C语言 每日一题 PTA 10.28 day6

2023-10-28 18:04
文章标签 语言 每日 day6 pta 10.28

本文主要是介绍C语言 每日一题 PTA 10.28 day6,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.求奇数分之一序列前N项和

本题要求编写程序,计算序列 1 + 1 / 3 + 1 / 5 + ... 的前N项之和。
输入格式 :
输入在一行中给出一个正整数N。
输出格式 :
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后6位。题目保证计算结果不超过双精度范围。

思路

输入一个数N,定义此序列的多少项之和,分母每一项加2,一项项相加,循环进行求和,最后输出浮点数,要求精确到小数点后六位

代码实现:

int main()
{int N = 0;double i = 0;double sum = 0;printf("请您输入你想得到的前几项之和:\n");scanf("%d", &N);for (i = 1; i <= N; i = i + 2) {sum = sum + 1 / i;}printf("%.6lf", sum);return 0;
}

运行结果:

2.求简单交错序列前N项和

本题要求编写程序, 计算序列 1 - 1 / 2 + 1 / 3 - 1 / 4 + ... 的前N项之和。
输入格式 :
输入在一行中给出一个正整数N。
输出格式 :
在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后三位。题目保证计算结果不超过双精度范围。

思路

输入一个数N,定义此序列的多少项之和,后判定除数是奇数偶数,奇数符号为+,偶数符号为-,最后将他们求和。

代码实现:

int main()
{double S = 0;int N = 0;printf("请输入N的值:\n");scanf("%d", &N);int i = 0;for (i = 1; i <= N; i++) {if (i % 2 == 0) {S = S - 1.000 / i;}else {S = S + 1.000 / i;}}printf("sum = %lf", S);return 0;
}

运行结果:

3. 输出华氏 - 摄氏温度转换表

输入2个正整数lower和upper(lower≤upper≤100),请输出一张取值范围为[lower,upper]、且每次增加2华氏度的华氏 - 摄氏温度转换表。
温度转换的计算公式:C = 5×(F−32) / 9,其中:C表示摄氏温度,F表示华氏温度。

思路

输入范围的两个数,从范围左的数每次加2直至不小于等于范围右边的数,将每次得到的数用公式转换为华氏温度,得到最终的温度转换表

代码实现:

int main()
{int lower = 0;int upper = 0;double C = 0;printf("请您输入两个正整数:\n");scanf("%d %d", &lower, &upper);double num = (double)lower;if (lower <= upper && upper <= 100){for (num=lower; num <= upper; num = num + 2){C = 5 * (num - 32) / 9;printf("%.1lf\n", C);}}else {printf("Invalid.");}return 0;
}

运行结果: 

4.找出最小值

本题要求编写程序,找出给定一系列整数中的最小值。
输入格式:
输入在一行中首先给出一个正整数n,之后是n个整数,其间以空格分隔。
输出格式:
在一行中按照“min = 最小值”的格式输出n个整数中的最小值。

思路

定义输入个数后,从头进行输入,先将第一个输入的数定义为最小值,对输入的数和当前最小值进行比较,如果输入的数小于当前的最小值,则将当前输入的数赋值给最小值,最后求得输入的数中的最小值

代码实现

#include <stdio.h>
int main() {int n, m, t, i;printf("输入正整数个数n\n");scanf("%d", &n);printf("输入第一个数\n");scanf("%d", &t);for (i = 1; i < n; i++) {printf("输入第%d个数\n", i + 1);scanf("%d", &m);if (m < t){t = m;}}printf("min = %d\n", t);return 0;
}

运行结果

5.统计素数并求和

本题要求统计给定整数M和N区间内素数的个数并对它们求和。
输入格式 :
输入在一行中给出两个正整数M和N(1≤M≤N≤500)。
输出格式 :
在一行中顺序输出M和N区间内素数的个数以及它们的和,数字间以空格分隔。

思路 

素数的判定从一个数遍历到另一个数字,中间如果遇到了求余为0的数,则跳出嵌套循环,跳出后判断两个数是否相等,如果相等,则是素数

代码实现

#include<stdio.h>
int main()
{int j, i;int m, n;int num = 0, sum = 0;printf("请您输入区间的值,中间用空格隔开:\n");scanf("%d %d", &m, &n);for (i = m; i <= n; i++){for (j = 2; j <= i; j++){if (i % j == 0)break;}if (j == i){sum += i;num++;}}printf("%d %d\n", num, sum);
}

运行结果

这篇关于C语言 每日一题 PTA 10.28 day6的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/294995

相关文章

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

Go语言使用Buffer实现高性能处理字节和字符

《Go语言使用Buffer实现高性能处理字节和字符》在Go中,bytes.Buffer是一个非常高效的类型,用于处理字节数据的读写操作,本文将详细介绍一下如何使用Buffer实现高性能处理字节和... 目录1. bytes.Buffer 的基本用法1.1. 创建和初始化 Buffer1.2. 使用 Writ

深入理解C语言的void*

《深入理解C语言的void*》本文主要介绍了C语言的void*,包括它的任意性、编译器对void*的类型检查以及需要显式类型转换的规则,具有一定的参考价值,感兴趣的可以了解一下... 目录一、void* 的类型任意性二、编译器对 void* 的类型检查三、需要显式类型转换占用的字节四、总结一、void* 的

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

PTA求一批整数中出现最多的个位数字

作者 徐镜春 单位 浙江大学 给定一批整数,分析每个整数的每一位数字,求出现次数最多的个位数字。例如给定3个整数1234、2345、3456,其中出现最多次数的数字是3和4,均出现了3次。 输入格式: 输入在第1行中给出正整数N(≤1000),在第二行中给出N个不超过整型范围的非负整数,数字间以空格分隔。 输出格式: 在一行中按格式“M: n1 n2 ...”输出,其中M是最大次数,n

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return