黑马汉子


私信TA

用户名:zhou2438262

访问量:777

签 名:

等  级
排  名 19668
经  验 713
参赛次数 0
文章发表 1
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

解题思路:根据题意,我们需要3个步骤:1,定义两个字符型数组,并给第一个数组赋值;2将第一个数组中我们所需要的字符挑出来并赋值给第二个数组;3,对第二个数组进行排序。然后就可以进行输出了。



注意事项:第二个数组一定要加上结束符,否则你会很“烫”。

参考代码:

#include<stdio.h>

#include<string.h>

void copy(char x[],char y[])  //自定义拷贝函数

{

  int i,j=0;

  for(i=0;x[i]!='\0';i++)     

  {

     if(x[i]=='a' || x[i]=='e' || x[i]=='i' || x[i]=='o' || x[i]=='u')  //将符合要求的字符拷贝到第二个字符组

{

   y[j]=x[i];

   j++;                   //记录第二个字符组的有效长度

}

  }

  y[j]='\0';                 //加上结束符

}

void px(char x[])            //自定义排序函数

{

  int len,i,j,change;

  len=strlen(x);

  for(j=0;j<len-1;j++)       

  {

for(i=0;i<len-1-j;i++)   //-j的作用是每循环一轮,则下一次可以少比较一个,因为最后一个一定是ASCII码最大的,无需再比较

{

       if(x[i]>x[i+1])       //ASCII码小的字符靠前,大的靠后排列

   {

      change=x[i+1];

      x[i+1]=x[i];

      x[i]=change;

   }

}

  }

  x[len]='\0';               //加上结束符

}

int main()

{

  char a[1000],b[1000];

  gets(a);

  copy(a,b);

  px(b);

  puts(b);

  return 0;

}


 

0.0分

0 人评分

  评论区

  • «
  • »