C语言之字符数组

第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关:字符串处理

题目描述:编写程序,输入字符串s1s2以及插入位置f,在字符串s1中的指定位置f处插入字符串s2。如输入"BEIJING""123"3,则输出:"BEI123JING"

输入 第一行和第二行分别输入两个字符串s1s2,第三行输入插入位置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关:字符插入

题目描述:输入两个字符串ab,将b串中的最大字符插入到a串中最小字符后面。

输入 输入一段文字

输出 输入两个字符串ab

样例输入:

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;
}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

又是被bug折磨的一天

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值