第1关:字符逆序
任务描述
题目描述:输入一个字符串,输出反序后的字符串。
相关知识(略)
编程要求
请仔细阅读右侧代码,结合相关知识,在Begin-End
区域内进行代码补充。 输入 一行字符 输出 逆序后的字符串
测试说明
样例输入: 123456abcdef
样例输出: fedcba654321
特别注意:样例输出没有进行换行操作
开始你的任务吧,祝你成功!
#include<stdio.h>
#include<string.h>
char s[1024];
int main()
{
scanf("%s",s);
int i;
for(i=strlen(s)-1;i>=0;i--)
putchar(s[i]);
putchar('\n');
return 0;
}
第2关:字符统计
任务描述
题目描述:对于给定的一个字符串,统计其中数字字符出现的次数。
相关知识(略)
编程要求
请仔细阅读右侧代码,结合相关知识,在Begin-End
区域内进行代码补充。 输入 输入数据有多行,第一行是一个整数n
,表示测试实例的个数,后面跟着n
行,每行包括一个由字母和数字组成的字符串。 输出 对于每个测试实例,输出该串中数值的个数,每个输出占一行。、
测试说明
样例输入: 2
asdfasdf123123asdfasdf
asdf111111111asdfasdfasdf
样例输出: 6
9
开始你的任务吧,祝你成功!
#include<stdio.h>
#include<string.h>
int main()
{
int n,count,i,k;
char a[500];
scanf("%d",&n);
while(n--)
{
count=0;
scanf("%s",&a);
k=strlen(a);
for(i=0;i<k;i++)
if(a[i]<'A')
count++;
printf("%d\n",count);
}
}
第3关:字符插入
任务描述
题目描述:输入两个字符串a
和b
,将b
串中的最大字符插入到a
串中最小字符后面。
相关知识(略)
编程要求
请仔细阅读右侧代码,结合相关知识,在Begin-End
区域内进行代码补充。 输入 输入一段文字 输出 输入两个字符串a
和b
。
测试说明
样例输入: MynameisAmy
MynameisJane
样例输出: MynameisAymy
提示: 字符串长度不超过100
注意:使用**gets()**函数会引起警告并不是报错,只要代码编译正确并不会影响测评结果。 推荐使用:fgets()函数。
开始你的任务吧,祝你成功!
#include<stdio.h>
#include<string.h>
int main(void)
{
int i,j,m,n;
int max,min;
char a[50],b[50];
gets(a);
gets(b);
m=strlen(a);
n=strlen(b);
for(i=0,min=0;i<m;i++)
if(a[min]>a[i])
min=i;
for(i=0,max=0;i<n;i++)
if(b[max]<b[i])
max=i;
for(j=m+1;j>min;j--)
a[j]=a[j-1];
a[j+1]=b[max];
puts(a);
return 0;
}
第4关:字符串处理
任务描述
题目描述:编写程序,输入字符串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>
# include <string.h>
int main(void)
{
char str1[100],str2[100],str3[200];
int n,t1,t2,i;
gets(str1);
gets(str2);
scanf("%d",&n);
t1=strlen(str1);
t2=strlen(str2);
for( i=0;i<t1+t2;i++)
{
if(i<n) str3[i]=str1[i];
else if(i<n+t2) str3[i]=str2[i-n];
else str3[i]=str1[i-t2];
}
str3[i]='\0';
puts(str3);
return 0;
}
第5关:字符串统计
任务描述
题目描述:输入一段字符(由空格、字母和数字几种组成,保证开头不为空格),里面有若干个字符串,求这些字符串的长度和,并输出最长字符串内容,如果有多个输出最先出现的那个字符串。以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()
{
int i,j=0,m,count,max;
char a[100];
while(1)
{
gets(a);
count=0;
max=0;
if(strcmp(a,"stop")==0)
break;
for(i=strlen(a)-1;i>=0;i--)
{
if(a[i]!=' '&&i!=0)
{
j++;
count++;
}
else if(a[i]==' '||i==0)
{
if(i==0)
{
j++;
count++;
}
if(j>=max)
{
max=j;
m=i;
if(i==0)
m=i-1;
}
j=0;
}
}
printf("%d ",count);
for(i=m+1;i<m+1+max;i++)
printf("%c",a[i]);
printf("\n");
}
return 0;
}
第6关:字符串排序
任务描述
题目描述:输入3
行,每行n
个字符串,按由小到大的顺序输出
相关知识(略)
编程要求
请仔细阅读右侧代码,结合相关知识,在Begin-End
区域内进行代码补充。 输入 3
行字符串 输出 按照从小到大输出成3
行
测试说明
样例输入: cde
afg
abc
样例输出: abc
afg
cde
开始你的任务吧,祝你成功!
#include <stdio.h>
#include <string.h>
int main() {
char a[3][128];
char temp[128];
for(int i=0;i<3;i++){
scanf("%s",a[i]);
}
for(int i=0;i<2;i++){
for(int j=i+1;j<3;j++){
if(strcmp(a[i],a[j])>-1){
strcpy(temp,a[i]);
strcpy(a[i],a[j]);
strcpy(a[j],temp);
}
}
}
for(int i=0;i<3;i++){
printf("%s\n",a[i]);
}
return 0;
}