字符串排序

问题描述:给一段字符串排序,存在一个key字符串,两个字符串中包含‘a’至‘z’的小写字母。首先按照key对input的字符串进行排序,然后对剩下的按字符大小排序。

Code:

  1 #include <stdio.h>
  2
  3 void keysort(char *str,char *key)
  4 {
  5     if(str==NULL) return;
  6     int hash[26]={0};
  7     for(int i=0;str[i]!='\0';i++)
  8         hash[str[i]-'a']++;
  9     while(*key!='\0')
 10     {
 11         for(int j=hash[*key-'a'];j>0;j--)
 12         {
 13             *str=*key;
 14             str++;
 15             hash[*key-'a']--;
 16         }
 17         key++;
 18     }
 19     for(char ch='a';ch<='z';ch++)
 20     {
 21         for(int j=hash[ch-'a'];j>0;j--)
 22         {
 23             *str=ch;
 24             str++;
 25             hash[ch-'a']--;
 26         }
 27     }
 28 }
 29 int main()
 30 {
 31     char str[]="helloworldnicetomeetyou";
 32     char key[]="low";
 33     printf("%s\n",str);
 34     keysort(str,key);
 35     printf("%s\n",str);
 36     return 0;
 37 }

Output:

[root@localhost Test]# ./a.out
helloworldnicetomeetyou
llloooowcdeeeehimnrttuy

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值