解题思路:

定义两个字符数组,在第一个输入的数组中判断字符串中是否有元音字母,如果有则输入第二个数组。

然后由第二个数组执行元音字母的排序。

最后调用输出即可。

注意事项:

注意多语句别漏了花括号

参考代码:

#include <stdio.h>
#include <string.h>
int yuanyin(char a[],char b[])
{
	int i,j=0,k,l;
	char x;
	l=strlen(a);
	for(i=0;i<l;i++)
	{
		if(a[i]=='a'||a[i]=='e'||a[i]=='i'||a[i]=='o'||a[i]=='u')
		{
			b[j]=a[i];
			j++;
		}
	}
	b[j]='\0';
	k=strlen(b);
	for(i=0;i<k;i++)
	{
		for(j=i;j<k;j++)
		{
			if(b[i]>b[j])
			{
			x=b[j];b[j]=b[i];b[i]=x; 
			}
		 }
	}
    return 0;
}
int main()
{
	char a[100],b[100];
	gets(a);
	yuanyin(a,b);
	puts(b);
	return 0;
}


点赞(0)
 

0.0分

67 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 60 条评论

外物 2年前 回复TA
#include<stdio.h>
int main()  
{
    char a[100];
    int i;
    gets(a);
    
    for(i=0;i<strlen(a);i++)
    {
        if(a[i]=='a'||a[i]=='e'||a[i]=='i'||a[i]=='o'||a[i]=='u')
        printf("%c",a[i]);
    }
	return 0;
}
江湖人 2年前 回复TA
@uq_87534612122 并且只用考虑小写吗?
江湖人 2年前 回复TA
@uq_87534612122 自定义函数里面的那个嵌套函数的作用是啥呀
江湖人 2年前 回复TA
第二个那个嵌套循环是干啥的呀?
学学薛 2年前 回复TA
@奋斗的嘉 @3268621743 看题目是啥
奋斗的嘉 2年前 回复TA
@奋斗的嘉 @2321548335 主函数也是函数啊,况且这个编译通过了
郁猪猪 2年前 回复TA
#include<stdio.h>
#include<string.h>
int main(){
    char str[100],a[1000];
    int i,len,j;
    gets(str);
    len = strlen(str);
    j=0;
    for(i=0;i<len;i++){
        if(str[i]=='a'||str[i]=='e'||str[i]=='i'||str[i]=='o'||str[i]=='u'){
            a[j] = str[i];
            j++;
        }
    }
    a[j] = '\0';
    puts(a);
}
范德萨 2年前 回复TA
@奋斗的嘉 函数呢?
奋斗的嘉 2年前 回复TA
额,都太麻烦了吧
看我的:#include<stdio.h>
int main()
{char a;
  while((a=getchar())!=EOF){
  	if(a=='a'||a=='e'||a=='i'||a=='o'||a=='u'){
	  	printf("%c",a);
	  }
  	
  }
	
	
}
oula 2年前 回复TA
void Out(char a[])
{
    char buff[2048];
    int length = 0;
    int i = 0;
    while (a[i] != '\0')
    {
        switch (a[i])
        {
        case 'a':
        case 'e':
        case 'i':
        case 'o':
        case 'u':
        buff[length] = a[i];
        length++;
            break;
        
        default:
            break;
        }
        i++;
    }
    buff[length] = '\0';
    for(int i = 0;i < length;i++)
    {
        printf("%c" ,buff[i]);
    }
    
}