C语言头歌:字符数组

文章介绍了几个关于字符串操作的编程问题,包括字符逆序、统计数字字符、插入特定字符、处理字符串插入和字符串排序等,涉及C语言编程实现。
摘要由CSDN通过智能技术生成

第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关:字符插入

任务描述

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

相关知识(略)
编程要求

请仔细阅读右侧代码,结合相关知识,在Begin-End区域内进行代码补充。 输入 输入一段文字 输出 输入两个字符串ab

测试说明

样例输入: 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关:字符串处理

任务描述

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

相关知识(略)
编程要求

请仔细阅读右侧代码,结合相关知识,在Begin-End区域内进行代码补充。 输入 第一行和第二行分别输入两个字符串s1s2,第三行输入插入位置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;
} 

  • 25
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值