EDUCoder编程练习题解(循环一)

2024-04-08 17:48

本文主要是介绍EDUCoder编程练习题解(循环一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

编辑与调试    顺序结构    选择结构一    选择结构二    循环一     循环二    函数
递归与嵌套函数     一维数组和二维数组     字符数组      指针一    指针二     结构体      文件

循环一

第1关:小球自由落体运动
任务描述
一球从M米高度自由下落,每次落地后返回原高度的一半,再落下。 它在第N次落地时反弹多高?共经过多少米? 结果保留两位小数。

输入
从键盘输入M和N的值。

输出
它在第N次落地时反弹多高?共经过多少米? 保留两位小数,空格隔开,放在一行。

测试说明
平台会对你编写的代码进行测试,若是与预期输出相同,则算通关。
样例输入:
1000 5
样例输出:
31.25 2875.00

解题说明:
注意大坑:经过多少米是指最后到落地经过了多少米,最后一次没有反弹的!
解题程序:

/* 第1关:小球自由落体运动 */#include<stdio.h>
int main(void)
{/*********Begin*********/float m;int n, i;scanf("%f%d", &m, &n);float sum = m;for(i = 1; i <= n; i++) {if(i > 1)sum += m + m;m /= 2;}printf("%.2f %.2f\n", m, sum);/*********End**********/return 0;
}

第2关:求解出n以内所有能被5整除的正整数的乘积
任务描述
本关任务:求解出n以内(包含n)所有能被5整除的正整数数的乘积s。

输入
输入包含多个样例,每个样例一个正整数n,占一行。读取到文件结尾。输入的n不超过100。

输入格式

scanf(“%d”, &n)
输出
对于每个样例n,输出n以内(包含n)所有能被5整除的正整数的乘积。
输出格式

printf(“%d\n”, s);

测试说明
平台会对你编写的代码进行测试,若是与预期输出相同,则算通关。
样例输入:
19
样例输出:
750

解题程序:

/* 第2关:求解出n以内所有能被5整除的正整数的乘积 */#include<stdio.h>
int main(void)
{  /*********Begin*********/int n;while(scanf("%d", &n) != EOF) {int p = 1, i; for(i = 5; i <= n; i += 5)p *= i; printf("%d\n", p);  }/*********End**********/ return 0;
}

第3关:最大公约数和最小公倍数
任务描述
本关任务:输入两个正整数m和n,求其最大公约数和最小公倍数。

输入
从键盘上任意输入两个数。

输出
分两行输出,第一行输出:最大公约数是多少;第二行输出最小公倍数是多少。

测试说明
平台会对你编写的代码进行测试,若是与预期输出相同,则算通关。
样例输入
2 3
样例输出
最大公约数是:1
最小公倍数是:6

解题程序:

/* 第3关:最大公约数和最小公倍数 */#include<stdio.h>int gcd(int n, int m)
{return m == 0 ? n : gcd(m, n % m);
}int main(void)
{  /*********Begin*********/int n, m;scanf("%d%d", &n, &m);int g = gcd(n, m);printf("最大公约数是:%d\n", g);printf("最小公倍数是:%d\n", n / g * m);  /*********End**********/ return 0;
}

第4关:字符串中各类字符数的统计
任务描述
本关任务:输入一行字符,分别统计出其中英文字母、数字、空格和其他字符的个数。

输入
一行字符。
输出
统计每种字符的个数值。

样例输入:
aklsjflj123 sadf918u324 asdf91u32oasdf/.';123
样例输出:
23 16 2 4

解题程序(2种):

/* 第4关:字符串中各类字符数的统计 */#include<stdio.h>
#include<ctype.h>#define N 1024
char s[N +1];int main(void)
{  /*********Begin*********/int letter = 0, digit = 0, space = 0, other = 0, i;fgets(s, N, stdin);for(i = 0; s[i] != '\n'; i++)if(isalpha(s[i])) letter++;else if(isdigit(s[i])) digit++;else if(isspace(s[i])) space++;else other++;printf("%d %d %d %d\n", letter, digit, space, other);  /*********End**********/ return 0;
}
/* 第4关:字符串中各类字符数的统计 */#include<stdio.h>
#include<ctype.h>#define N 1024
char s[N +1];int main(void)
{  /*********Begin*********/int letter = 0, digit = 0, space = 0, other = 0, i;fgets(s, N, stdin);for(i = 0; s[i] != '\n'; i++)if('a'<=s[i]&&s[i]<='z'||'A'<=s[i]&&s[i]<='Z') letter++;else if('0'<=s[i]&&s[i]<='9') digit++;else if(s[i] == ' ') space++;else other++;printf("%d %d %d %d\n", letter, digit, space, other);  /*********End**********/ return 0;
}

第5关:求sn=a+aa+aaa+aaaa+…的值
任务描述
本关任务:键盘输入正整数a和n,编程 s=a+aa+aaa+aaaa+aa…a(n个a)的值。
例如:
a=2 ,n=5时,表示计算由2组成的数的和:2+22+222+2222+22222 ( 此时 共有5个数相加)。

输入:5 3 表示3个由5组成的数相加,即计算5+55+555的值,输出:615

输入:5 4 表示计算5+55+555+5555的值,输出:6170

测试说明
以下是测试样例:

输入:5 3
输出:615
输入:6 4
输出:7404
输入:3 5
输出:37035

解题代码:

/* 第5关:求sn=a+aa+aaa+aaaa+......的值 */#include<stdio.h>int main(void)
{  /*********Begin*********/int a, n, t = 0, sum = 0, i;scanf("%d%d", &a, &n);for(i = 1; i <= n; i++) {t *= 10, t += a;sum += t;}printf("%d\n", sum);  /*********End**********/ return 0;
}

编辑与调试    顺序结构    选择结构一    选择结构二    循环一     循环二    函数
递归与嵌套函数     一维数组和二维数组     字符数组      指针一    指针二     结构体      文件

这篇关于EDUCoder编程练习题解(循环一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

Python循环缓冲区的应用详解

《Python循环缓冲区的应用详解》循环缓冲区是一个线性缓冲区,逻辑上被视为一个循环的结构,本文主要为大家介绍了Python中循环缓冲区的相关应用,有兴趣的小伙伴可以了解一下... 目录什么是循环缓冲区循环缓冲区的结构python中的循环缓冲区实现运行循环缓冲区循环缓冲区的优势应用案例Python中的实现库

Java嵌套for循环优化方案分享

《Java嵌套for循环优化方案分享》介绍了Java中嵌套for循环的优化方法,包括减少循环次数、合并循环、使用更高效的数据结构、并行处理、预处理和缓存、算法优化、尽量减少对象创建以及本地变量优化,通... 目录Java 嵌套 for 循环优化方案1. 减少循环次数2. 合并循环3. 使用更高效的数据结构4

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

Python判断for循环最后一次的6种方法

《Python判断for循环最后一次的6种方法》在Python中,通常我们不会直接判断for循环是否正在执行最后一次迭代,因为Python的for循环是基于可迭代对象的,它不知道也不关心迭代的内部状态... 目录1.使用enuhttp://www.chinasem.cnmerate()和len()来判断for

Java循环创建对象内存溢出的解决方法

《Java循环创建对象内存溢出的解决方法》在Java中,如果在循环中不当地创建大量对象而不及时释放内存,很容易导致内存溢出(OutOfMemoryError),所以本文给大家介绍了Java循环创建对象... 目录问题1. 解决方案2. 示例代码2.1 原始版本(可能导致内存溢出)2.2 修改后的版本问题在