C语言程序设计9

问题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

result

问题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

result

问题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));
}

结果9_3

result

  • 20
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值