PTA平台习题---写一个函数,输入一行字符,将此字符串中最长的单词输出

本文介绍了一个C语言函数,该函数能够接收一串字符作为输入,并找出并打印出其中最长的单词。通过使用计数器和标记变量,函数能够准确地跟踪每个单词的长度,并确定最长单词的起始位置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/*写一个函数,输入一行字符,将此字符串中最长的单词输出*/
void longest(){
    int flag=0,count=0,maxLength=0,index=0;	//count用来计数当前单词长度,index是最长单词的下标位置。
    int i,j;
    char words[30],ch;
    printf("请输入一行字符:\n");
    gets(words);
    
    for(i=0;i<strlen(words)+1;i++){	//这里不用while((ch=words[i])!='\0')的原因,i*love****china字符串为例,字符串在字符数组中的存储实际上是如下:i*love****china\0,系统最后会帮加上一个\0用来做字符串结束的判断。如果用while的写法或者for没有+1,最后的china的长度因为不会再进入循环而不会被记录。如果结尾处连续是数字,且数字长度最长,则结果不准确。
        ch=words[i];
        
        if(('a'<=ch&&ch<='z')||('A'<=ch&&ch<='Z')){	
            flag=1;	//如果是单词则标记flag=1,且单词计数+1
            count++;
        }else if (flag==1){	//当不是单词,且前一个为单词的时候才开始判断是否最长单词。为何需要判断前一个是否为单词?如果遇到 I*love****china 这样的字符串,当e过后,连续的****会标记错love单词Index的位置。所以这里不用else而用else if的原因就是为了多一个判断。
            if(count>maxLength){	
                index=i-count;	//计算最长单词的下标位置
                maxLength=count;
            }
            flag=0;
            count=0;
        }
    }
    for(j=index;j<index+maxLength;j++){
        printf("%c",words[j]);
    }
    printf("\n");
}
### 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]。 --- #### 总结 综合以上讨论可知,解决字符串变换类问题需要清晰定义目标规则并严格遵循编程规范实施。同时,面对复杂情况应具备良好的调试策略以便快速发现问题根源。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值