PTA初级题库7-130,最佳情侣身高差 getchar()

7-130 最佳情侣身高差

分数 4

作者 陈越

单位 浙江大学

专家通过多组情侣研究数据发现,最佳的情侣身高差遵循着一个公式:(女方的身高)×1.09 =(男方的身高)。如果符合,你俩的身高差不管是牵手、拥抱、接吻,都是最和谐的差度。

下面就请你写个程序,为任意一位用户计算他/她的情侣的最佳身高。

输入格式:

输入第一行给出正整数N(≤10),为前来查询的用户数。随后N行,每行按照“性别 身高”的格式给出前来查询的用户的性别和身高,其中“性别”为“F”表示女性、“M”表示男性;“身高”为区间 [1.0, 3.0] 之间的实数。

输出格式:

对每一个查询,在一行中为该用户计算出其情侣的最佳身高,保留小数点后2位。

输入样例:

2
M 1.75
F 1.8

输出样例:

1.61
1.96

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

代码:

​
#include<stdio.h>
int main()
{
    int n;scanf("%d",&n);
    getchar();//吞掉换行符,因为下一个是用%c输入,如果不吞掉换行符,则s内存的是换行符而不是M或F
    char s;float sum;
    while(n--)//用while代替for循环,更简单
    {
        scanf("%c%f",&s,&sum);getchar();//吞掉换行符
        if(s=='M')printf("%.2f\n",sum/1.09);
        if(s=='F') printf("%.2f\n",sum*1.09);
    }
}

​

### PTA 7-1 字符串变换 练习题 解析 PTA 7-1 的题目通常涉及字符串操作,可能要求实现某种特定的字符串转换逻辑。虽然具体题目未提供,但可以推测该题的核心在于对字符串的操作能力,比如反转、替换子串或其他形式的处理。 以下是基于常见字符串变换类问题的一个通用解决方案: #### 题目分析 假设此题的目标是对给定字符串执行某些变换操作(如大小写转换、删除指定字符等)。此类问题的关键点包括但不限于: - 输入字符串的格式化读取。 - 对字符串中的每个字符逐一处理。 - 输出满足条件的结果。 以下是一个典型的 C/C++ 实现方案,用于演示如何完成类似的字符串变换任务。 ```c #include <stdio.h> #include <string.h> void transformString(char str[]) { int i, len = strlen(str); for (i = 0; i < len; i++) { if (str[i] >= 'a' && str[i] <= 'z') { // 小写字母转大写 str[i] -= ('a' - 'A'); } else if (str[i] >= 'A' && str[i] <= 'Z') { // 大写字母保持不变 continue; } else { // 非字母字符移除 memmove(&str[i], &str[i + 1], strlen(&str[i])); i--; // 调整索引以重新检查当前位置 len--; } } } int main() { char inputStr[1024]; printf("Enter a string: "); fgets(inputStr, sizeof(inputStr), stdin); // 使用fgets安全读入字符串 inputStr[strcspn(inputStr, "\n")] = '\0'; // 去掉换行符 transformString(inputStr); printf("Transformed String: %s\n", inputStr); return 0; } ``` 上述代码实现了将输入字符串中小写字母转化为大写字母的功能,并移除了所有非字母字符[^1]。 --- #### 关于调试技巧 如果在解决过程中遇到错误输出的情况,可以通过逐步验证每一步骤来定位问题所在。例如,在平方探测法的应用场景下,可能会因误解算法而导致结果偏[^2]。此时建议采用如下方法排查: - **单元测试**:针对每一部分功能单独设计测试用例。 - **日志打印**:在关键位置加入 `printf` 或其他调试工具记录中间状态。 对于系统调用层面的问题,需了解底层机制。例如,当使用 `getchar()` 函数获取键盘输入时,其行为依赖于缓冲区管理以及 ASCII 编码规则[^3]。 --- #### 总结 综合以上讨论可知,解决字符串变换类问题需要清晰定义目标规则并严格遵循编程规范实施。同时,面对复杂情况应具备良好的调试策略以便快速发现问题根源。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值