解题思路:

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

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

最后调用输出即可。

注意事项:

注意多语句别漏了花括号

参考代码:

#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 条评论

liu2022 2年前 回复TA
@玛卡巴卡 有大神能帮我看看出什么问题了吗
liu2022 2年前 回复TA
@玛卡巴卡 #include <stdio.h> #include <string.h>  char a[],b[],c[]; int k,j;    int yuan(char a[])  {  	for (k=0;k<strlen(a);k++)  	{  		if (a[k]==&#039;a&#039;)  		b[0]=&#039;a&#039;;  		else   		b[0]=032;  		if (a[k]==&#039;e&#039;)  		b[1]=&#039;e&#039;;  		else   		b[1]=032;  		if (a[k]==&#039;i&#039;)  		b[2]=&#039;i&#039;;  		else   		b[2]=032;  		if (a[k]==&#039;o&#039;)  		b[3]=&#039;o&#039;;  		else   		b[3]=032;  		if (a[k]==&#039;u&#039;)  		b[4]=&#039;u&#039;;  		else   		b[4]=032; 	 } 	 for (k=0,j=0;k<5||j<5;j++) 	 { 	 	if (b[k]!=032) 	 	{ 	 		c[j]=b[k]; 	 		k++; 		 } 	 	if (b[k]==032) 		 { 		 	k++; 		 	j--; 		 } 	 } 	 for (k=0;k<5;k++) 	 { 	 	printf ("%c",c[k]); 	 } 	 return 0;  } /* run this program using the console pauser or add your own getch, system("pause") or input loop */  int main(int argc, char *argv[]) { 	gets (a); 	 yuan(a); 	return 0; }
2年前 回复TA
没叫你排序啊
王建鑫 2年前 回复TA
#include<stdio.h>
char a[1000],i;
void Zftq(char a[1000])
{
	for( i=0;a[i]!='\0';i++)
	{
		if(a[i]=='a' || a[i]=='e' || a[i]=='i' || a[i]=='o' || a[i]=='u')
		{
			printf("%c",a[i]);	
		}
	}
}
int main()
{
	gets(a);
	Zftq(a);
	return 0;
}
萌萌哒的大耗子 2年前 回复TA
@玛卡巴卡 不符合原题题意
玛卡巴卡 2年前 回复TA
#include<stdio.h>
#include<string.h>
int main()
{
	char a[1000];
	char b[1000];
	int i,j,l;
	gets(a);
	l = strlen(a);
	for(i = 0,j = 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';
	puts(b);
	return 0;
}
玛卡巴卡 2年前 回复TA
#include<stdio.h>
int main()
{
	char a[1000];
	int i;
	gets(a);
	for(i = 0;a[i] != '0';i++)
	{
		if(a[i] == 'a'||a[i] == 'e'||a[i] == 'i'||a[i] == 'o'||a[i] == 'u')
		{
			printf("%c",a[i]);
		}
	}
}
uq_87534612122 2年前 回复TA
#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=1;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;
}
SeeUAG 2年前 回复TA
#include <stdio.h>
#include <string.h>

int main() {
    int fun(char str1[], char str2[]);
    char str1[50], str2[50];
    scanf("%s", str1);
    fun(str1, str2);
    printf("%s", str2);
    return 0;
}

int fun(char str1[], char str2[]) {
    int i, j = 0, n;
    n = strlen(str1);
    for (i = 0; i <= n; i++) {
        if ('a' == str1[i] || 'e' == str1[i] || 'i' == str1[i] || 'o' == str1[i] || 'u' == str1[i]) {
            str2[j] = str1[i];
            j++;
        } else
            printf("");
    }
    return 0;
}

什么问题呢?
harder 2年前 回复TA
#include "stdio.h"
#include "string.h"

int main() {
	int i, j = 0, k, t, m;
	char a[100];
	char b[100];
	gets(a);
	m = strlen(a);
	for (i = 0; i <= m; i++)
		if (a[i] == 'a' || a[i] == 'e' || a[i] == 'i' || a[i] == 'o' || a[i] == 'u') {
			b[j] = a[i];
			j++;
		}
	k = strlen(b);
	for (i = k; j >= 0; j--)
		for (j = 0; j <= i - 1; i++)

			if (b[j] > b[j + 1]) {
				t = b[j];
				b[j] = b[j + 1];
				b[j + 1] = t;
			}
	for (i = 0; i <= k - 1; i++)
		printf("%c", b[i]);
	return 0;
}
兄弟们为嘛我的时间超限了呜呜呜