第1关:字符逆序
100
- 任务要求
- 评论973
任务描述
题目描述:输入一个字符串,输出反序后的字符串。
相关知识(略)
编程要求
请仔细阅读右侧代码,结合相关知识,在Begin-End
区域内进行代码补充。 输入 一行字符 输出 逆序后的字符串
测试说明
样例输入: 123456abcdef
样例输出: fedcba654321
特别注意:样例输出没有进行换行操作
开始你的任务吧,祝你成功!
#include<stdio.h>
int main(void)
{
/*********Begin*********/
char a[20],b[20];
int i,j,n=0;
gets(a);
for(i=0;a[i]!='\0';i++)
n++;
for(i=0,j=n-1;a[i]!='\0';i++,j--)
b[j]=a[i];
puts(b);
/*********End**********/
return 0;
}
第2关:字符统计
100
- 任务要求
- 评论973
任务描述
题目描述:对于给定的一个字符串,统计其中数字字符出现的次数。
相关知识(略)
编程要求
请仔细阅读右侧代码,结合相关知识,在Begin-End
区域内进行代码补充。 输入 输入数据有多行,第一行是一个整数n
,表示测试实例的个数,后面跟着n
行,每行包括一个由字母和数字组成的字符串。 输出 对于每个测试实例,输出该串中数值的个数,每个输出占一行。、
测试说明
样例输入: 2
asdfasdf123123asdfasdf
asdf111111111asdfasdfasdf
样例输出: 6
9
开始你的任务吧,祝你成功!
#include<stdio.h>
int main(void)
{
/*********Begin*********/
int n;
scanf("%d",&n);
char a[n][30];
int i,s=0,j;
for(i=0;i<n;i++){
scanf("%s",&a[i]);
}
for(i=0;i<n;i++){
s=0;
for(j=0;a[i][j]!='\0';j++){
if(a[i][j]>='0'&&a[i][j]<='9'){
s++;
}
}
printf("%d\n",s);
}
/*********End**********/
return 0;
}
第3关:字符插入
100
- 任务要求
- 参考答案
- 评论973
任务描述
题目描述:输入两个字符串a
和b
,将b
串中的最大字符插入到a
串中最小字符后面。
相关知识(略)
编程要求
请仔细阅读右侧代码,结合相关知识,在Begin-End
区域内进行代码补充。 输入 输入一段文字 输出 输入两个字符串a
和b
。
测试说明
样例输入: MynameisAmy
MynameisJane
样例输出: MynameisAymy
提示: 字符串长度不超过100
注意:使用gets()**函数会引起警告并不是报错,只要代码编译正确并不会影响测评结果。 **推荐使用:fgets()函数。
开始你的任务吧,祝你成功!
#include <stdio.h>
#include <string.h>
int main(void)
{
/*********Begin*********/
char a[100],b[100];
gets(a),gets(b);
int i,n=0,x=0;
char min=a[0],max=b[0];
for(i=0;a[i]!='\0';i++){
if(a[i]<min){
min=a[i];
n=i;
}
}
for(i=0;b[i]!='\0';i++){
if(b[i]>max){
max=b[i];
x=i;
}
}
for(i=0;i<=n;i++){
printf("%c",a[i]);
}
printf("%c",b[x]);
for(i=n+1;a[i]!='\0';i++){
printf("%c",a[i]);
}
/*********End**********/
return 0;
}
第4关:字符串处理
100
- 任务要求
- 参考答案
- 评论973
任务描述
题目描述:编写程序,输入字符串s1
和s2
以及插入位置f
,在字符串s1
中的指定位置f处插入字符串s2
。如输入"BEIJING"
, "123"
, 3
,则输出:"BEI123JING"
。
相关知识(略)
编程要求
请仔细阅读右侧代码,结合相关知识,在Begin-End
区域内进行代码补充。 输入 第一行和第二行分别输入两个字符串s1
和s2
,第三行输入插入位置f
。
每个字符串的长度不超过100
个字符。 输出 输出一行插入后的字符串。
测试说明
样例输入: BEIJING
123
3
样例输出: BEI123JING
注意:使用gets()**函数会引起警告并不是报错,只要代码编译正确并不会影响测评结果。 **推荐使用:fgets()函数。
开始你的任务吧,祝你成功!
#include<stdio.h>
int main(void)
{
/*********Begin*********/
char s1[100],s2[100];
int n;
scanf("%s%s%d",s1,s2,&n);
int i;
for(i=0;i<n;i++){
printf("%c",s1[i]);
}
printf("%s",s2);
for(i=n;s1[i]!='\0';i++){
printf("%c",s1[i]);
}
/*********End**********/
return 0;
}
第5关:字符串统计
100
- 任务要求
- 参考答案
- 评论973
任务描述
题目描述:输入一段字符(由空格、字母和数字几种组成,保证开头不为空格),里面有若干个字符串,求这些字符串的长度和,并输出最长字符串内容,如果有多个输出最先出现的那个字符串。以stop
作为最后输入的字符串。
相关知识(略)
编程要求
请仔细阅读右侧代码,结合相关知识,在Begin-End
区域内进行代码补充。 输入 输入一段文字 输出 输入一段字符,以stop
作为最后输入的字符串。
测试说明
样例输入: My name is Amy
My name is Jane
stop
样例输出: 11 name
12 name
提示: 字符串长度不超过100
。
注意:使用gets()
函数会引起警告,但正确使用不影响测评结果。 推荐使用:fgets()
函数。
开始你的任务吧,祝你成功!
#include<stdio.h>
#include <string.h>
int main()
{
/*********Begin*********/
int sum=0,part=0,max=0,i,j;
char a[100];
gets(a);
while(strcmp(a,"stop")!=0){
for(i=0;a[i]!=0;i++){
if(a[i]!=' '){
sum++,part++;
}else{
if(part>max){
max=part;
}
part=0;
}
}
if(part>max)
max=part;
part=0;
for(i=0;a[i]!=0;i++){
if(a[i]!=' '){
part++;
if(part==max){
for(j=0;j<max;j++){
a[j]=a[j+i-max+1];
}
a[max]='\0';
goto out;
}
}else{part=0;}
}
out:
printf("%d ",sum);
puts(a);
//再进行第二组循环
sum=0,part=0,max=0;
gets(a);
}
/*********End**********/
return 0;
}
第6关:字符串排序
100
- 任务要求
- 参考答案
- 评论973
任务描述
题目描述:输入3
行,每行n
个字符串,按由小到大的顺序输出
相关知识(略)
编程要求
请仔细阅读右侧代码,结合相关知识,在Begin-End
区域内进行代码补充。 输入 3
行字符串 输出 按照从小到大输出成3
行
测试说明
样例输入: cde
afg
abc
样例输出: abc
afg
cde
开始你的任务吧,祝你成功!
#include<stdio.h>
#include<string.h>
int main()
{
/*********Begin*********/
char a[100],b[100],c[100];
int x,y,z;
gets(a),gets(b),gets(c);
x=strcmp(a,b);//进行比较,大于0为a>b
y=strcmp(a,c);
z=strcmp(b,c);
if(x>0&&y>0&&z>0)
puts(c),puts(b),puts(a);
else if(x>0&&y>0&&z<0)
puts(b),puts(c),puts(a);
else if(x<0&&y>0&&z>0)
puts(c),puts(a),puts(b);
else if(x<0&&y<0&&z>0)
puts(a),puts(c),puts(b);
else if(x>0&&y<0&&z<0)
puts(b),puts(a),puts(c);
else
puts(a),puts(b),puts(c);
/*********End**********/
return 0;
}