代码编织梦想

前言

今天是刷题第10天,放弃不难,但坚持一定很酷~

快来跟我一起刷题吧。

在这里插入图片描述


81.连接两个字符串

输入两个字符串 strl 和 st2,对输入的字符串进行长度比较,然后将小的连接在大的字符串后面,最后输出连接好的新串并计算新串的长度。

题目分析:本题有两种解法,第一种是直接使用C语言里面的库函数,第二种是自己模拟对应的库函数。

方法一:使用库函数

#include<stdio.h>
#include<string.h>
int main()
{
 int len;
 char str1[80], str2[80];
 printf("输入字符串1:\n");
 scanf("%s", str1);
 printf("输入字符串2:\n");
 scanf("%s", str2);
 if (strlen(str1)>= strlen(str2))
 {
  strcat(str1, str2);
  len = strlen(str1);
  printf("连接后的字符串为:%s,长度为:%d\n", str1, len);
 }
 else
 {
  strcat(str2, str1);
  len = strlen(str2);
  printf("连接后的字符串为:%s,长度为:%d\n", str2, len);
 }
 return 0;
}

这里使用了两个字符串函数,我们分别介绍一下。

strlen函数:求字符串的长度。
在这里插入图片描述

strcat函数:连接两个字符串
在这里插入图片描述

方法二:使用自己模拟的函数
首先我们可以模拟一下strlen函数,strlen函数的作用就是计算字符串的长度。对于该函数,我们有三种方法可以进行模拟。
模拟方法一:循环+计数器模拟

int strlen1 (char * str)
{
 int count = 0;
 while(*str)
 {
 count++;
 str++;
 }
 return count;
}

模拟方法二:递归模拟

int strlen2 (char * str)
{
 if(*str == '\0')
 return 0;
 else
 return 1 + strlen2(str+1);
}

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

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);
                        }
                    }
                }
            }
        }
    }
    return 0;
}
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_61084441/article/details/127992924

百日计划:第一周,《七周成为数据分析师》课程近万字总结_无小意的博客-爱代码爱编程

无小意 个人博客:无小意 知乎主页:无小意丶 公众号: 数据路(shuju_lu) 百日计划第一周总结 1. 计划 1.彻底结束之前预定暑假完成的天善学院课程《七周数据分析师》 2.总结《七周数据分析

百日刷题挑战--错题01day_不虚此行-rui的博客-爱代码爱编程

1.在 32 位编译器上,设有定义 1 char *str1 = "Hello", str2[] = "Hello";  则以下语句 1  printf("%d %d", sizeof(str1), sizeof(str2));  的输出结果是(6,6) 解析: str1是指针 大小为4字节 str2是字符数

c语言百日刷题第一天_子夜的星的博客-爱代码爱编程

C语言刷题第一天 1.判断一个整数n是否是闰年2.输入4个数,输出其中最大的数3. 二的n次方计算4.判断这个整数能被 2 3 7 中哪几个数整除,并按升序输出5.判断三角形类型6. 输出99乘法表7.反向输出一个四

c语言百日刷题第二天_子夜的星的博客-爱代码爱编程

C语言百日刷题第二天 11. 统计输入数据的正负个数12.学生基本信息输入输出13.杨辉三角的前n行14.模拟用户登录情景15.演示多个字符从两端移动,向中间汇聚16.计算短信费用17.编写函数不允许创建临时变量,求

c语言百日刷题第三天_子夜的星的博客-爱代码爱编程

C语言百日刷题第三天 21.时间转换22.计算总成绩和平均分23.计算体重指数24.计算三角形的周长和面积25.大小写转换26.输入一个十六进制数a,和一个八进制数b,输出a+b的十进制结果27.从键盘任意输入一个字

c语言百日刷题第五天_子夜的星的博客-爱代码爱编程

C语言百日刷题第五天 41.实现一个函数,打印乘法口诀表,口诀表的行数和列数自己指定42.实现一个函数来交换两个整数的内容。43.实现一个函数来进行整型有序数组的二分查找44.接收一个无符号整型,按照它们的顺序打印每

c语言百日刷题第八天_子夜的星的博客-爱代码爱编程

前言 今天是刷题第8天,放弃不难,但坚持一定很酷~ 快来跟我一起刷题吧。 刷题第八天目录 前言71.打印7层杨辉三角形72.重新排列数组73.冒泡排序74.将数字变成0的操作次数75.四叶玫瑰数

c语言百日刷题第三天_北卡澜的博客-爱代码爱编程

目录 11.车厢重组 12.Cantor表(升级版) 13.硬币翻转 14.peter的烟 15.字数整数 11.车厢重组 题目分析:很多人看到看到把相邻两节车厢交换,估计都想到冒泡排序,但是这题没让我们排序,只让我们输出最少旋转次数 先上冒泡排序 #include<stdio.h> int main(){

c语言百日刷题第四天_北卡澜的博客-爱代码爱编程

目录 1.用筛选法求100之内的素数 2.用选择法对10个整数排序  3.求一个3*3的整型矩阵的对角线之和 4.有一个已排序好的数组,要求输入一个数后,按原来排序的规律将它插入数组中 5.将一个数组中的值按逆序排放 生活不止眼前的苟且还有诗和远方!!!这些天交杂这备赛,又经历一下午一道题没写出来,差点崩溃,但还是相信坚持下来一定很

c语言百日刷题第九天_子夜的星的博客-爱代码爱编程

前言 今天是刷题第9天,放弃不难,但坚持一定很酷~ 快来跟我一起刷题吧。 加油,一起努力进步 C语言百日刷题第九天 前言76.计算偶数的所有质因子77. 提取不重复的整数78.二进制中1的个数79.猴

c语言百日刷题第五天_北卡澜的博客-爱代码爱编程

目录  1.杨辉三角 2.找出一个二维矩阵的鞍点 3.折半查找法 4.统计文章字符  5.输出图形 固然山腰的风景很美,但我还是想去山顶看看。所以,诸君咱们山顶见!!!  1.杨辉三角 题目分析:1.每一行的第一个和最后一个元素都为1 2.其它元素为其正上方的元素及正上方左边的元素之和 #include<st

百日大刷题no.1_cs semi的博客-爱代码爱编程

百日大刷题 一、字符串逆序二、C语言经典问题之汽水问题1.解析2.非递归做法(不调用函数)3.非递归做法(调用函数)3.递归做法 三、打印实心菱形四、水仙花数升级版(自幂数)总结 一、字符串逆序 闲话不多

c语言百日刷题第四天_矩阵相邻元素有公约数-爱代码爱编程

C语言百日刷题第四天 31.打印100~200之间的素数32.给定两个数,求这两个数的最大公约数33.计算1!+2!+.....+n!34.在一个有序数组中查找某个具体的数字n(二分查找法)35.演示多个字符从

c语言百日刷题第六天-爱代码爱编程

C语言百日刷题第六天 51.鸡兔同笼问题52.输出所有形如aabb的完全平方数53.3n+1问题54.输出100~999的所有水仙花数55.韩信点兵56.倒三角形57.求子序列的和58.分数化小数59.开灯问题

c语言百日刷题第七天_216最小生成元-爱代码爱编程

C语言百日刷题第七天 61. 写一个函数isPowerOfTwo判断是不是2的幂次方62. 写一个函数isPowerOfThree判断是不是3的幂次方63.n 的第 k 个因子64.有效的完全平方数65.搜索旋

【0基础百日刷题】洛谷刷题知识拾遗_洛谷刷题指南-爱代码爱编程

百日刷题 一.洛谷刷题得1.P1420差分数组2.P2669数列求和3.P1307数字反转4.P5725三角形5.P1980计数问题6.P1217回文质数