PTA 基础编程题目 7-13

PTA

基础编程题目

7-13 日K蜡烛图 (15 分)
股票价格涨跌趋势,常用蜡烛图技术中的K线图来表示,分为按日的日K线、按周的周K线、按月的月K线等。以日K线为例,每天股票价格从开盘到收盘走完一天,对应一根蜡烛小图,要表示四个价格:开盘价格Open(早上刚刚开始开盘买卖成交的第1笔价格)、收盘价格Close(下午收盘时最后一笔成交的价格)、中间的最高价High和最低价Low。

如果Close<Open,表示为“BW-Solid”(即“实心蓝白蜡烛”);如果Close>Open,表示为“R-Hollow”(即“空心红蜡烛”);如果Open等于Close,则为“R-Cross”(即“十字红蜡烛”)。如果Low比Open和Close低,称为“Lower Shadow”(即“有下影线”),如果High比Open和Close高,称为“Upper Shadow”(即“有上影线”)。请编程序,根据给定的四个价格组合,判断当日的蜡烛是一根什么样的蜡烛。

输入格式:
输入在一行中给出4个正实数,分别对应Open、High、Low、Close,其间以空格分隔。

输出格式:
在一行中输出日K蜡烛的类型。如果有上、下影线,则在类型后加上with 影线类型。如果两种影线都有,则输出with Lower Shadow and Upper Shadow。

输入样例1:
5.110 5.250 5.100 5.105
输出样例1:
BW-Solid with Lower Shadow and Upper Shadow
输入样例2:
5.110 5.110 5.110 5.110
输出样例2:
R-Cross
输入样例3:
5.110 5.125 5.112 5.126
输出样例3:
R-Hollow

代码示例

本人小白,个人想法

#include <stdio.h>
#include <stdlib.h>

int main()
{
    double Open,High,Low,Close;
    scanf("%lf%lf%lf%lf",&Open,&High,&Low,&Close);
    if(Close<Open)
        printf("BW-Solid");
    else if(Close>Open)
        printf("R-Hollow");
    else
        printf("R-Cross");
    if(Low<Open&&Low<Close&&High>Open&&High>Close)
        printf(" with Lower Shadow and Upper Shadow");
    else if(Low<Open&&Low<Close)
        printf(" with Lower Shadow");
    else if(High>Open&&High>Close)
        printf(" with Upper Shadow");
}

仍旧是一道,先读懂题意,然后先对蜡烛类型进行区分,再根据影线的类型进行区分即可。

### PTA 平台上的 Python 基础编程练习题 PTA (Programming Teaching Assistant) 是一个在线评测系统,广泛用于高校计算机课程的教学辅助工作。该平台上提供了丰富的 Python 编程题目供学生练习。 对于希望提高 Python 编程技能的学生来说,在 PTA 上可以找到许多基础级别的编程练习题。这些题目通常覆盖了 Python 的核心概念和技术要点,帮助学习者逐步掌握这门语言基础知识[^1]。 下面是一个典型的 Python 练习题实例: #### 题目描述 编写程序接受一系列由空白分隔的单词作为输入,并打印去除所有重复单词并按字母顺序排列后的结果。 #### 输入格式 一行字符串,表示多个被空格分开的单词。 #### 输出格式 去重后按照字典序排序的一行字符串。 #### 示例代码实现如下: ```python def remove_duplicates_and_sort(): # 获取用户输入的数据 words = input().split() # 使用集合来消除重复项再转回列表以便排序 unique_words = list(set(words)) # 对唯一单词列表进行排序 sorted_unique_words = sorted(unique_words) # 将排序好的单词连接成单个字符串输出 result = ' '.join(sorted_unique_words) print(result) remove_duplicates_and_sort() ``` 此段代码实现了从控制台读取一串以空格分割的词语,通过 `set()` 函数删除其中可能出现的任何重复词项,之后利用内置函数 `sorted()` 来对剩余的独特词汇做升序处理最后组合起来形成新的句子返回给调用方显示出来[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值