第一题:从后往前扫描一遍,根据当前统计的'#'的数目,对每个字母向后移动相同数目的位置。 const int maxn = 1000+10; char s[maxn]; void solve() { int n = strlen(s); int cnt = 0; for(int i=n-1 ; i>=0 ; --i){ if(s[i]=='#'){ ++cnt; }else{ s[i+cnt] = s[i]; } } for(int i=0 ; i<cnt ; ++i){ s[i] = '#'; } }
点赞 2

相关推荐

12-13 14:51
已编辑
井冈山大学 算法工程师
龙虾x:算法比你强的没有你美,比你美的…..算了已经没有比你美的了
工作两年想退休了
点赞 评论 收藏
分享
牛客网
牛客网在线编程
牛客网题解
牛客企业服务