字符串移动

本文详细介绍了两种方法解决字符串问题:一种是通过遍历字符串,将星号移动到最左侧;另一种是先统计星号数量,然后在原字符串中将非星号元素依次向右移动对应的星号数量,最终填充剩余位置为星号。方法旨在实现时间和空间复杂度的最小化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转自出处



字符串为*号和26个字母、阿拉伯数字的任意组合,把*号都移动到最左侧,把其他字母和数字都移到最右侧并保持相对顺序不变,返回字符*的个数,要求时间和空间复杂度最小。
第一种方法:跟上面的重排问题是一样的

[cpp]  view plain copy
  1. int MoveStar(char *str , int n)  
  2. {  
  3.     int i , j = n-1;  
  4.     for(i = n - 1 ; i >= 0 ; --i)  
  5.     {  
  6.         if(str[i] != '*')  
  7.         {  
  8.             if(str[j] == '*')  
  9.             {  
  10.                 str[j] = str[i];  
  11.                 str[i] = '*';  
  12.             }  
  13.             --j;  
  14.         }  
  15.     }  
  16.     return j+1;  
  17. }  
第二种方法:
[cpp]  view plain copy
  1. int MoveStar(char *str , int n)  
  2. {  
  3.     int i , count = 0;  
  4.     for(i = n - 1 ; i >= 0 ; --i)  
  5.     {  
  6.         if(str[i] == '*')  
  7.             ++count;  
  8.         else if(count > 0)    // str[i] != '*'  
  9.             str[i + count] = str[i];  
  10.     }  
  11.     for(i = 0 ; i < count ; ++i)  
  12.         str[i] = '*';  
  13.     return count;  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值