【机试刷题】HJ31 单词倒排 解法
朴素解法:
#include <stdio.h>
#include <string.h>
int main(){
char c;
char word[100][22]={'\0'};
int num=0,top=0;
while((c = getchar())!=EOF){
if(c>='a'&&c<='z'||c>='A'&&c<='Z')
word[num][top++]=c;
else{
num++;
top=0;
}
}
for(int i=num-1;i>=0;i--){
printf("%s ",word[i]);
}
return 0;
}
特殊解法1:利用scanf的正则表达式高级功能
#include <stdio.h>
#include <stdlib.h>
int main(){
char str[100][22];
int i=0;
int x;
while(1){
x=scanf("%[a-z|A-Z]",str[i]);
if(getchar()=='\n') break;
if(x) i++;
}
for(int j=i;j>=0;j--){
printf("%s ",str[j]);
}
return 0;
}
或者
三、scanf 函数中的正则表达式使用
在 C 语言中,scanf 函数支持正则表达式。通过在格式控制字符串中添加特殊的字符,可以实现对输入数据的正则表达式匹配。这些特殊字符包括:
1.百分号(%):表示匹配任意字符。
2.问号(?):表示匹配前面的子表达式零次或一次。
3.*:表示匹配前面的子表达式零次或多次。
4.+:表示匹配前面的子表达式一次或多次。
5.{n}:表示匹配前面的子表达式 n 次。
6.{n,}:表示匹配前面的子表达式 n 次或多次。
7.{n,m}:表示匹配前面的子表达式 n 到 m 次。
8.^:表示匹配行的开始位置。
9.$:表示匹配行的结束位置。
10.[abc]:表示匹配方括号内的任意一个字符(a、b 或 c)。
11.[^abc]:表示匹配除方括号内字符以外的任意字符。
12.(pattern):表示匹配 pattern 并捕获结果,以便后续引用。
13|:表示或操作,匹配两个模式之一。
合集:
牛客华为面试题
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2018-12-22 Getting started with Processing 第十一章——数组