昨天我们介绍了如何删除字符串中的某一段数据但不改变字符串的顺序,有时我们所期望的字符串顺序与实际顺序并不相同,在今天我们介绍如何为一段字符串重新排序

【问题】:

下列给定程序中,函数fun的功能是:将s所指字符串中的所有数字字符移到所有非数字字符之后,并保持数字字符串和非数字字符串原有的次序。
例如,s所指的字符串为"def35adh3kjsdf7",执行后结果为"defadhajsdf3537"。
请在程序的下画线处填入正确的内容把下画线删除,使程序得出正确的结果。
注意:部分源程序在文件BLANK1.C中。
不得增行或删行,也不得更改程序的结构!


【程序】:

#include    <stdio.h>
void fun(char *s)
{ int i, j=0, k=0; char t1[80], t2[80];
for(i=0; s[i]!='\0'; i++)
if(s[i]>='0' && s[i]<='9')
{
/**********found**********/
t2[j]=s[i]; ___1___;
}
else t1[k++]=s[i];
t2[j]=0; t1[k]=0;
/**********found**********/
for(i=0; i<k; i++) ___2___;
/**********found**********/
for(i=0; i<___3___; i++) s[k+i]=t2[i];
}main()
{ char s[80]="ba3a54j7sd567sdffs";
printf("\nThe original string is : %s\n",s);
fun(s);
printf("\nThe result is : %s\n",s);
}


---------------------------------

【参考答案】
(1)j++或j+=1或++j或j=j+1
(2)s[i]=t1[i]  (3) j

【解析】:
本题考查:指针型变量;数组变量赋值;for循环语句。

填空1:根据函数fun中的内容可知,数组t1存储了s中的非数字字符,数组t2存储了s中的数字字符,为了存储下一个数字字符,下标j要进行加1操作。
填空2:将s串中的数字与非数字字符分开后,要先将非数字字符放入字符串s中,因此填入s[i]=t1[i]。
填空3:最后将数字字符加到s串之后,并且i要小于数字的个数j。

【程序填空题】字符串的排序_数组