C语言百日刷题第十天_胖肚子决定从明天开始的 n 天中,任意选择 k 天进行工作。 给定一个整数

模拟方法三:指针运算模拟

int strlen3 (char \*s)
{
       char \*p = s;
       while(\*p != ‘\0’ )
              p++;
       return p-s;
}

接下来,我们可以尝试去模拟一下strcat函数,而strcat函数的原理其实就是先找到目标字符串的结尾(‘\0’),然后从此处开始进行数据的复制,当找到源字符串的结束标志(’\0’)时停止复制。

char \*strcat1(char \*dest, const char\*src)
{
 char \*ret = dest;
 assert(dest != NULL); //断言防止为空指针
 assert(src != NULL);  //断言防止为空指针
 while(\*dest)
 {
	dest++;
 }
 while(\*dest = \*src)
{
	dest++;
	src++;
}
 return ret;
}

如此一来,我们就模拟了两个字符串函数,接下来把他们封装,直接调用就行了,这里的strlen函数我就使用第一种模拟的函数吧。

#include<stdio.h>
#include<assert.h>
int strlen1(char\* str)
{
	int count = 0;
	while (\*str)
	{
		count++;
		str++;
	}
	return count;
}
char\* strcat1(char\* dest, const char\* src)
{
	char\* ret = dest;
	assert(dest != NULL); //断言防止为空指针
	assert(src != NULL);  //断言防止为空指针
	while (\*dest)
	{
		dest++;
	}
	while (\*dest = \*src)
	{
		dest++;
		src++;
	}
	return ret;
}
int main()
{
	int len;
	char str1[80], str2[80];
	printf("输入字符串1:\n");
	scanf("%s", str1);
	printf("输入字符串2:\n");
	scanf("%s", str2);
	if (strlen1(str1) >= strlen1(str2))
	{
		strcat1(str1, str2);
		len = strlen1(str1);
		printf("连接后的字符串为:%s,长度为:%d\n", str1, len);
	}
	else
	{
		strcat1(str2, str1);
		len = strlen1(str2);
		printf("连接后的字符串为:%s,长度为:%d\n", str2, len);
	}
	return 0;
}

82.输入一行字符,分别统计其中英文字母、空格、数字和其他字符的个数。

输入一行字符,分别统计其中英文字母、空格、数字和其他字符的个数。

在这里插入图片描述

题目分析:分别统计英文、空格和数字,及其其他,我们自然就想到了使用分支语句进行判断,那么如何进行判断以上四种情况呢,柿子先捡软的捏,最容易判断的当然就是空格,其次就是英文字母和数字,最难判断的就是其他字符,但是如果我们把前面三种都判断了,那么最后的不就剩下其他字符了嘛?但是因为我们不知道用户输入的具体是多少,所以我们无法判断分支语句写多少条,所以我们就应该用循环,因为我们输入完后会敲回车,而回车相当于换行,所以我们要将换行作为循环结束的标志。

#include<stdio.h>
int main()
{
	char c;
	int letter = 0, space = 0, digit = 0, other = 0;
	printf("请输入需要统计的字段:\n");
	while ((c = getchar()) != '\n')
	{
		if (c >= 'a' && c <= 'z' || c >= 'A' && c <= 'Z')
			letter++;
		else if (c == ' ')
			space++;
		else if (c >= '0' && c <= '9')
			digit++;
		else
			other++;
	}
	printf("英文有:%d\n空格有:%d\n数字有:%d\n其他有:%d", letter, space, digit, other);
	return 0;
}

83.写一个排序函数实现数组从小到大的排序

排序的方法有很多,这里我写一个我比较常用的排序方法-------快速排序。
快速排序的核心思想就是分治,这里我提供一个我比较常用的模板。

#include<stdio.h>
//快速排序的实现
void quick\_sort(int q[], int left, int right)
{
    if (left >= right)
        return;
    int i = left - 1, j = right + 1, x = q[left + right >> 1];// >>一位相当于除以二
    while (i < j)
    {
        do i++; while (q[i] < x);
        do j--; while (q[j] > x);
        if (i < j)
        {
            int tmp;
            tmp = q[i];
            q[i] = q[j];
            q[j] = tmp;
        }
    }
    //递归处理左右边界
    quick\_sort(q, left, j), quick\_sort(q, j + 1, right); 
}
//验证
int main()
{
    int q[10] = { 1,2,56,2552,5,325,2,69,348,222 };
    quick\_sort(q, 0, 9);
    for (int i = 0; i < 10; i++)
    {
        printf("%d ", q[i]);
    }
    return 0;
}

84.字母的大小写转换

从键盘输入一个字符,判断其是否为大写字母,若是大写字母,则将其转换为小写;否则,不进行转换。

题目分析:本题的核心是了解ASCII码之间的关系,从表上来看,对于字母来说,小写的字母的ASCII码比大写的ASCII码值大32
在这里插入图片描述

代码如下:

#include<stdio.h>
int main()
{
	char input;
	scanf("%c", &input);
	if (input >= 'A' && input <= 'Z')
	{
		input = input + 32;
	}
	printf("%c", input);
	return 0;
}

85.找乒乓球队名单

在这里插入图片描述

现有两个乒乓球队进行比赛,各出三人。甲队为A,B,C 三人,乙队为X,Y,Z 三人。已抽签决定比赛名单。有人向队员打听比赛的名单。A说他不和X比,C说他不和X,Z比,请编程序找出三队赛手的名单。

分析:需要通过循环进行比较,并且需要if语句来判断参赛队员是否重复。

#include<stdio.h>
int main()
{
    for (char i = 'X'; i <= 'Z'; i++)
    {
        for (char j = 'X'; j <= 'Z'; j++)
        {
            if (i != j)
            {
                for (char k = 'X'; k <= 'Z'; k++)
                {
                    if (i != k && j != k)
                    {
                        if (i != 'X' && k != 'X' && k != 'Z')
                        {
                            printf("A对%c\nB对%c\nC对%c\n", i, j, k);


![img](https://img-blog.csdnimg.cn/img_convert/743de6253b3aebc080b10ee3e86a5d65.png)
![img](https://img-blog.csdnimg.cn/img_convert/601bb7f6920f4d8373760780a6a5db76.png)
![img](https://img-blog.csdnimg.cn/img_convert/12a675f591487ae12b900fd69e9e52af.png)

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**

[外链图片转存中...(img-cBSZgv86-1714227080623)]

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值