解题思路:
在解这个题之前我曾经接触过一个统计单词的题。从那个题得到了灵感,通过标志位判断是否为一个单词,同时进行字母计数。
注意事项:
参考代码:
#include <stdio.h>
#include <ctype.h>
#include <string.h>
int main()
{
int n,i,num,j=0,temp=0;
char ar[100000];
int flag=0; //1为在单词中,0为在单词外
fgets(ar,100000,stdin);
num=strlen(ar);
for(i=0;i<num;i++)
{
if(isalpha(ar[i])) //当为字母时j++
{
j++;
}
if(isalpha(ar[i])&&flag==0) //当刚好进入单词的第一个字母时
{
flag=1;
}
if(!isalpha(ar[i])&&flag==1) //刚好离开单词时
{
flag=0;
if(j>temp)
{
temp=j; //通过比较留下最长的单词的字母数
n=i; //记下最长的单词最后一个字母所在的后一个位置
}
j=0;
}
}
for(i=n-temp;i<n;i++)
printf("%c",ar[i]);
return 0;
}
0.0分
1 人评分
内部收益率 (C++代码)浏览:2349 |
川哥的吩咐 (C++代码)浏览:1051 |
【明明的随机数】 (C++代码)浏览:821 |
printf基础练习2 (C语言代码)浏览:820 |
C语言程序设计教程(第三版)课后习题7.1 (C语言代码)浏览:1258 |
三角形 (C++代码)记忆化搜索浏览:1300 |
C语言程序设计教程(第三版)课后习题8.8 (C语言代码)浏览:885 |
IP判断 (C语言描述,蓝桥杯)浏览:1106 |
C语言程序设计教程(第三版)课后习题9.3 (C语言代码)浏览:647 |
C语言程序设计教程(第三版)课后习题10.7 (用指针求解)浏览:1526 |