第6关:字符串排序
题目描述:输入3
行,每行n
个字符串,按由小到大的顺序输出
参考博客地址:(2条消息) EduCoder-程序设计技术R(第六部分字符数组)- 第6关:字符串排序_is_kevin_cen的博客-CSDN博客
输入 3
行字符串
输出 按照从小到大输出成3
行
#include<string.h>
#include<stdio.h>
int main(void)
{
/*********Begin*********/
char s1[200],s2[200],s3[200];
int sum_s1=0,sum_s2=0,sum_s3=0;
scanf("%s",s1);
scanf("%s",s2);
scanf("%s",s3);
if(strcmp(s1, s2) <= 0) {
if(strcmp(s2, s3) <= 0)
printf("%s\n%s\n%s\n", s1, s2, s3);
else {
if(strcmp(s3, s1) <= 0)
printf("%s\n%s\n%s\n", s3, s1, s2);
else
printf("%s\n%s\n%s\n", s1, s3, s2);
}
} else {
if(strcmp(s1, s3) <= 0)
printf("%s\n%s\n%s\n", s2, s1, s3);
else {
if(strcmp(s3, s2) <= 0)
printf("%s\n%s\n%s\n", s3, s2, s1);
else
printf("%s\n%s\n%s\n", s2, s3, s1);
}
}
return 0;
}
第5关:字符串统计
题目描述:输入一段字符(由空格、字母和数字几种组成,保证开头不为空格),里面有若干个字符串,求这些字符串的长度和,并输出最长字符串内容,如果有多个输出最先出现的那个字符串。以stop
作为最后输入的字符串。
输入 输入一段文字
输出 输入一段字符,以stop
作为最后输入的字符串。
样例输入: My name is Amy
My name is Jane
stop
样例输出: 11 name
12 name
提示: 字符串长度不超过100
。
注意:使用gets()
函数会引起警告,但正确使用不影响测评结果。 推荐使用:fgets()
函数。
/* 第5关:字符串统计 */
#include<stdio.h>
#include <string.h>
#define N 1024
char s[N + 1], t[N + 1];
int main(void)
{
/*********Begin*********/
fgets(s, N, stdin);
for(;;) {
if(strncmp(s, "stop", 4) == 0 && s[4] == '\n')
break;
int sum = 0, maxlen = 0;
char *p;
p = strtok(s, " \t\n");
while(p) {
int len = strlen(p);
if(len > maxlen) {
maxlen = len;
strcpy(t, p);
}
sum += len;
p = strtok(NULL, " \t\n");
}
printf("%d %s\n", sum, t);
fgets(s, N, stdin);
}
/*********End**********/
return 0;
}
第4关:字符串处理
题目描述:编写程序,输入字符串s1
和s2
以及插入位置f
,在字符串s1
中的指定位置f处插入字符串s2
。如输入"BEIJING"
, "123"
, 3
,则输出:"BEI123JING"
。
输入 第一行和第二行分别输入两个字符串s1
和s2
,第三行输入插入位置f
。
每个字符串的长度不超过100
个字符。
输出 输出一行插入后的字符串。
样例输入:
BEIJING
123
3
样例输出:
BEI123JING
#include<stdio.h>
#include<string.h>
int main(void)
{
/*********Begin*********/
char s1[200],s2[200];
int f;
scanf("%s",s1);
scanf("%s",s2);
scanf("%d",&f);
for(int i=strlen(s1)-1;i>f-1;i--){//找到插入位置f,并将该位置之后的元素统一往后挪一位
s1[i+strlen(s2)]=s1[i];
//printf("%c\n",s1[i]);
}
for(int j=0;j<strlen(s2);j++){//向s1中插入s2
s1[f+j]=s2[j];
}
//输出s1串
/*for(int i=0;i<strlen(s1);i++){
printf("%c",s1[i]);
}*/
printf("%s",s1);
/*********End**********/
return 0;
}
第3关:字符插入
题目描述:输入两个字符串a
和b
,将b
串中的最大字符插入到a
串中最小字符后面。
输入 输入一段文字
输出 输入两个字符串a
和b
。
样例输入:
MynameisAmy
MynameisJane
样例输出:
MynameisAymy
提示: 字符串长度不超过100
注意:使用gets()**函数会引起警告并不是报错,只要代码编译正确并不会影响测评结果。 **推荐使用:fgets()函数。
#include<stdio.h>
#include<string.h>
int main(void)
{
/*********Begin*********/
char a[100],b[100];
scanf("%s",a);
scanf("%s",b);
int num_b=0,max_b=b[0];
for(int i=0;i<strlen(b);i++){//找到b串中最大字符
if(max_b<b[i]){
max_b=b[i];
num_b=i;
}
}
int num_a=0,min_a=a[0];
for(int i=0;i<strlen(a);i++){//找到a串中最小字符
if(min_a>a[i]){
min_a=a[i];
num_a=i;
}
}
//将a中最小字符依次往后腾出一个位置,
for(int i=strlen(a)-1;i>=num_a+1;i--){
a[i+1]=a[i];
}
a[num_a+1]=max_b;
//输出a串
for(int i=0;i<strlen(a);i++){
printf("%c",a[i]);
}
/*********End**********/
return 0;
}
第2关:字符统计
题目描述:对于给定的一个字符串,统计其中数字字符出现的次数。
输入 输入数据有多行,第一行是一个整数n
,表示测试实例的个数,后面跟着n
行,每行包括一个由字母和数字组成的字符串。
输出 对于每个测试实例,输出该串中数值的个数,每个输出占一行。、
样例输入:
2
asdfasdf123123asdfasdf
asdf111111111asdfasdfasdf
样例输出:
6
9
#include<stdio.h>
#include<string.h>
int main(void)
{
/*********Begin*********/
int n,c=0;
scanf("%d",&n);
char s[n][100];
for(int i=0;i<n;i++){
scanf("%s",s[i]);
}
for(int i=0;i<n;i++){
c=0;
for(int j=0;j<strlen(s[i]);j++){
if(s[i][j]>='0'&&s[i][j]<='9'){
c++;
}
}
printf("%d\n",c);
}
/*********End**********/
return 0;
}
第1关:字符逆序
题目描述:输入一个字符串,输出反序后的字符串。
输入
一行字符
输出
逆序后的字符串
测试说明
样例输入:
123456abcdef
样例输出:
fedcba654321
特别注意:样例输出没有进行换行操作
#include <stdio.h>
#include <string.h>
int main(void)
{
char s[100];
scanf("%s",s);
for(int i=strlen(s)-1;i>=0;i--){
printf("%c",s[i]);
}
return 0;
}