问题9_1
函数
f
u
n
fun
fun 的功能是:将
s
s
s 所指字符串中的所有数字字符移到所有非数字字符之后,并保持数字字符串和非数字字符串原有的次序。
例如,
s
s
s 所指的字符串为
"
a
b
c
123
b
c
d
456
c
d
e
78
c
c
"
"abc123bcd456cde78cc"
"abc123bcd456cde78cc" ,执行结果为
"
a
b
c
b
c
d
c
d
e
c
c
12345678
"
"abcbcdcdecc12345678"
"abcbcdcdecc12345678" 。
代码9_1
#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'){
t2[j] = s[i];
j++;
}
else{
t1[k++] = s[i];
}
}
t2[j] = 0;
t1[k] = 0;
for(i=0; i<k; i++)
s[i] = t1[i];
for(i=0; i<j; i++)
s[k+i] = t2[i];
}
void main(void){
char s[80] = "abc123bcd456cde78cc";
printf("\nThe original string is: %s\n", s);
fun(s);
printf("\nThe result is: %s\n", s);
}
结果9_1
问题9_2
函数 f u n fun fun的功能是:用冒泡法对 6 6 6 个字符串进行升序排列。
代码9_2
#include<stdlib.h>
#include<string.h>
#include<conio.h>
#include<stdio.h>
#define MAXLINE 20
void fun(char* pstr[60]){
int i, j;
char *p;
for(i=0; i<5; i++){
for(j=i+1; j<6; j++){
if(strcmp(*(pstr+i),(pstr+j))>0){
p = *(pstr+i);
*(pstr+i) = *(pstr+j);
*(pstr+j) = p;
}
}
}
}
void main(void){
int i;
char *pstr[6], str[6][MAXLINE];
system("CLS");
for(i=0; i<6; i++)
pstr[i] = str[i];
printf("\nEnter 6 string(1 string at each line):\n");
for(i=0; i<6; i++)
scanf("%s", pstr[i]);
fun(pstr);
printf("The string after soring:\n");
for(i=0; i<6; i++)
printf("%s\n", pstr[i]);
}
结果9_2
问题9_3
函数
f
u
n
fun
fun的功能是:求
s
s
ss
ss 所指字符串中指定字符的个数,并返回此值。
例如,若输入字符串为
"
123412132
"
"123412132"
"123412132" ,输入字符为
′
1
′
'1'
′1′ , 输出
3
3
3 。
代码9_3
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#define M 81
int fun(char *ss, char c){
int i=0;
for(; *ss!='\0'; ss++){
if(*ss==c) i++;
}
return i;
}
void main(void){
char a[M], ch;
system("CLS");
printf("\nPlease enter a string:");
gets(a);
printf("\nPlease enter a char:");
ch = getchar();
printf("\nThe number of the char is:%d\n", fun(a,ch));
}