一起刷C语言菜鸟教程100题(27-35)

news2024/9/22 7:32:13

先说明这个虽然菜鸟教程也有答案,但是这个专栏的博客是自己过手写了一遍,有自己的理解,有些习题自己是变化了一些,更适合练手,也会写的更普遍一些~

今天我们一起继续刷题,链接放在这里供大家自行使用

C 语言经典100例 | 菜鸟教程 (runoob.com)

使用方法:

1.先看题目自己想思路,自己做

2.自己做不出来看解题思路,再次尝试

3.实在不会,看解题思路和代码一起理解


题目27:将所输入的n个字符,以相反顺序打印出来 

解题思路:

这个题有两种方法,第一种是用函数递归做出来这道题,这是菜鸟教程的方法,但是还有一种方法就是用循环,然后将第一个值和最后一个互换,第二个和倒数第二个互换。依此类推,直到到中间那个值(PS:下面这个代码的 c[ n ] ,一般 oj 下是可以用变量定义数组大小的,而VS是不支持的)

参考代码如下:

#include <stdio.h>
int main()
{
	printf("请输入你要输入几位数:>\n");
	int n = 0;
	scanf("%d", &n);
	char c[n];
	for (int i = 0; i <= n - 1; i++)
	{
		scanf("%c", &c[i]);
	}
	int left = 0;//从第一个开始的数组下标
	int right = sizeof(c)/sizeof(c[0]) - 1;//从最后一个开始的数组下标
	while (left <= right)
	{
		char a = c[left];
		c[left] = c[right];
		c[right] = a;
		left++;
		right--;
	}
	for (int i = 0; i <= n - 1; i++)
	{
		printf("%c", c[i]);
	}
	return 0;
}

题目28:有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁。问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后问第一个人,他说是10岁。请问第五个人多大? 

解题思路:

因为这个题每个人都比前一个人大两岁,所以就想到了递归,这里菜鸟教程写的很简洁,就直接用了

菜鸟教程代码如下:

#include <stdio.h>
 
int age(n)
int n;
{
    int c;
    if(n==1) c=10;
    else c=age(n-1)+2;
    return(c);
}
int main()
{
    printf("%d\n",age(5));
}

其中,上面的函数也可以写成如下图格式:

题目29:给一个n位的正整数,要求:一、求它是几位数,二、逆序打印出各位数字。

解题思路:

求它几位数只要让它一直除以10,每除一次就是一位,直到除到最后不能再除为止,直到它使几位数之后就可以打印逆序了,取余一次就是最后一位开始,再除以一次10,再取余就变成倒数第二位了,依此类推,就可以写出代码

参考代码如下:

#include <stdio.h>
int main()
{
	printf("请输入数字:");
	int n = 0, count = 0, m = 0;
	scanf("%d", &n);
	int num = n;
	while (n>0)
	{
		n = n / 10;
		count++;
	}
	printf("%d\n", count);//打印几位数字
	for (int i = 1; i <= count; i++)
	{
		m = num % 10;
		num /= 10;
		printf("%d", m);//打印逆序
	}
	return 0;
}

题目30:一个n位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同

解题思路:

这里我们要先判断他是几位数字,之后用最高位和最低位是否相等依次判断~

参考代码如下:

#include <stdio.h>
#include <math.h>
int main()
{
	printf("请输入数字:");
	int n = 0, count = 0, m = 0, x = 1;
	scanf("%d", &n);
	int num = n;
	while (n > 0)
	{
		n = n / 10;
		count++;
	}
    //这里的count是表示输入的是几位数
	while (count > 0)
	{
		int left = num/pow(10, count - 1);//这是最高位的数字
		int right = num % 10;//这是最低位数字
		if (left != right)
		{
			printf("不是回文数\n");
			x = 0;
			break;
		}
		num = num % (int)pow(10, count - 1);//这是去掉当前最高位的数字
		num /= 10;//这是去掉当前最低位数字
		count = count - 2;//因为少了两位所以下次求最高位也要少除10^2
	}
	if (x == 1)
		printf("是回文数\n");
	return 0;
}

题目31:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母。

解题思路:

首先我们需要知道周一到周日的英文分别为:

monday,tuesday,wednesday,thursday,friday,saturday,sunday

其中,周二周四,周六日需要再进行第二个字母的判断,我们只要在首字母一样的情况下加入一种判断即可,这里直接给出菜鸟教程的代码,很完善

菜鸟教程代码如下:

#include<stdio.h>
 
int main()
{
    char i,j;
    printf("请输入第一个字母:\n");
    scanf("%c",&i);
    getchar();//scanf("%c",&j);的问题,第二次是读入的一个换行符,而不是输入的字符,因此需要加一个getchar() 吃掉换行符
    switch(i)
    {
        case 'm':
            printf("monday\n");
            break;
        case 'w':
            printf("wednesday\n");
            break;
        case 'f':
            printf("friday\n");
            break;
        case 't':
            printf("请输入下一个字母\n");
            scanf("%c",&j);
            if (j=='u') {printf("tuesday\n");break;}
            if (j=='h') {printf("thursday\n");break;}
        case 's':
            printf("请输入下一个字母\n");
            scanf("%c",&j);
            if (j=='a') {printf("saturday\n");break;}
            if (j=='u') {printf("sunday\n"); break;}
        default :
            printf("error\n"); break;
    }
    return 0;
}

题目32:删除一个字符串中的指定字母,如:字符串 "aca",删除其中的 a 字母。

参考代码如下:

#include <stdio.h>
int main()
{
	char arr1[] = "aca";//字符串
	char arr2[] = "a";//要删除的字符
	int r = sizeof(arr2) / sizeof(arr2[0])-1;//除去'\0'删除字符的长度
	int len = sizeof(arr1) - 1;//除去'\0'字符串的长度
	int new = 0;
	char arr3[len+1] = { 0 };//新的数组
	for (int i = 0; i <= len - 1; i++)
	{
		for (int j = 0; j <= r - 1; j++)
		{
			if (arr1[i] == arr2[j])
			{
				break;
			}
			else
			{
				arr3[new] = arr1[i];//将不是删除元素的字符放到新的数组里面
				new++;
				break;
			}
		}
	}
	for (int i = 0; i <= new - 1; i++)
	{
		printf("%c", arr3[i]);
	}
	return 0;
}
题目33:判断一个数字是否为质数。

解题思路:

要想解决这个题,我们首先要知道什么是质数, 所谓质数就是除了1和本身之外其它都不能被整除,这就是质数,那么我们只要进行一个循环,从2开始,到这个数本身之前,让这个数字去除以这些数字,如果取余为0则说明不是质数,停止循环,其他则继续直到循环结束说明是质数,但是这里要注意,2是素数!

参考代码如下:

#include <stdio.h>
int main()
{
	int n = 0, i = 2;//
	scanf("%d", &n);
	if (n != 2)
	{
		for (i = 2; i <= n - 1; i++)
		{
			if (n % i == 0) {
				printf("不是素数\n");
				break;
			}
		}
	}
	if (i == n || n == 2)
		printf("是素数\n");
	return 0;
}
题目34:函数调用。

解题思路:

这里注意就是如果一个自定义函数写到了mian函数后面,需要再使用前进行声明,这里以菜鸟教程为例给大家讲一下~

菜鸟教程第27题为例,代码如下:

题目35:字符串反转,如将字符串 "www.runoob.com" 反转为 "moc.boonur.www"

解题思路:

跟27题很类似,但是是字符串,其它一样,将第一个值和最后一个互换,第二个和倒数第二个互换。依此类推,直到到中间那个值(PS:下面这个代码的 c[ n+1 ] ,一般 oj 下是可以用变量定义数组大小的,而VS是不支持的)

参考代码如下:

#include <stdio.h>
#include <string.h>
int main()
{
	printf("请输入你要输入几位:>\n");
	int n = 0;
	scanf("%d", &n);
	char c[n+1];//这里的n+1是因为字符串结束的标志是'\0',要留一个位置作为结束的标志
	scanf("%s", &c);
	int left = 0;
	int right = strlen(c)-1;
	while (left <= right)
	{
		char a = c[left];
		c[left] = c[right];
		c[right] = a;
		left++;
		right--;
	}
	printf("%s\n", c);
	return 0;
}

今天的内容就到这里啦~希望大家可以自己动手敲一遍,然后再改改题做,效果会更棒! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1947967.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

小红书(社招二面)算法原题

萝卜快跑涨价 距离我们上次谈 萝卜快跑 不足半月&#xff0c;萝卜快跑迎来了不少"反转"。 先是被曝远程后台有人操控&#xff0c;真实日成本超 400&#xff1a; 最近还被不少网友吐槽&#xff1a;萝卜快跑涨价了&#xff0c;如今价格和网约车持平。 据不少博主实测&a…

如何在 Windows 上安装并配置 VNC 远程连接树莓派,并结合Cpolar实现公网远程访问

目录 ⛳️推荐 前言 1. 使用 Raspberry Pi Imager 安装 Raspberry Pi OS 2. Windows安装VNC远程树莓派 3. 使用VNC Viewer公网远程访问树莓派 3.1 安装Cpolar步骤 3.2 配置固定的公网地址 3.3 VNC远程连接测试 4. 固定远程连接公网地址 4.1 固定TCP地址测试 ⛳️推荐…

FastAPI(六十九)实战开发《在线课程学习系统》接口开发--修改密码

源码见&#xff1a;"fastapi_study_road-learning_system_online_courses: fastapi框架实战之--在线课程学习系统" 之前我们分享了FastAPI&#xff08;六十八&#xff09;实战开发《在线课程学习系统》接口开发--用户 个人信息接口开发。这次我们去分享实战开发《在线…

【Linux操作系统】:进程间通信

目录 进程间通信介绍 1、进程间通信的概念 2、进程间通信的目的 3、进程间通信的本质 4、进程间通信的分类 管道 匿名管道 匿名管道的原理 pipe函数 创建匿名管道 管道的四种情况和五种特性 命名管道 使用命令创建命名管道 创建一个命名管道 命名管道的打开规则 …

Lc60---1189. “气球” 的最大数量(排序)---Java版

1.题目 2.思路 (1)用字典的方法,ballon,这个单词里面每个字母&#xff0c;需要的个数 (2)再创一个字典的方法统计&#xff0c;输入的字符串的字母的个数 (3)计算能拼凑出多少个“ballon" (4)代码解释 for (char c : text.toCharArray()) {count.put(c, count.getOrDefau…

【C++ —— AVL树】

C —— AVL树 AVL树的概念AVL树节点的定义AVL树的插入向上调整旋转左单旋右单旋左右双旋右左双旋 AVL树的高度AVL树的验证总结&#xff1a;代码 AVL树的概念 二叉搜索树虽可以缩短查找的效率&#xff0c;但如果数据有序或接近有序二叉搜索树将退化为单支树&#xff0c;查找元素…

在QT中使用多线程并发服务器(C++)

什么是多线程并发服务器&#xff1f;在QT里如何使用多线程并发服务器呢&#xff1f; 多线程并发服务器是一种网络服务器设计&#xff0c;它能够同时处理多个客户端的请求。在多线程服务器中&#xff0c;主线程负责监听和接受来自客户端的连接请求&#xff0c;每当有一个新的连…

DNS服务器的搭建

1、DNS服务器端软件 DNS 的域名解析都是 udp/53 . 主从之间的数据传输默认使 ⽤tcp/53 DNS服务器端软件&#xff1a; Bind是⼀款开放源码的DNS服务器软件&#xff0c;Bind由美国加州⼤学Berkeley&#xff08;伯克 利&#xff09;分校开发和维护的&#xff0c;全名为Berkele…

美容院如何提高门店销售业绩?博弈美业收银系统分享五大策略

美容院要如何增加门店业绩&#xff1f;各位老板可以考虑以下几个方面的策略&#xff1a; 一、品牌宣传和营销&#xff1a; • 制定全面的营销计划&#xff0c;包括线上和线下宣传。可以利用社交媒体、网站、本地广告等多种渠道提升品牌知名度。 • 开展促销活动吸引新客户&a…

PYTHON学习笔记(七、python数据结构--集合)

目录 &#xff08;4&#xff09;set集合 1、集合的创建方式 1&#xff09;使用{ }直接创建集合 2&#xff09;使用内置函数set( )创建集合 3&#xff09;使用“ 集合生成式 ”生成集合 2、集合的访问方式 1&#xff09;使用for循环遍历 3、集合的修改操作 4、集合的…

SvelteKit - 1. 初始化项目

官方 doc - create a project 1、基本环境 &#xff08;下面是我这里的环境&#xff0c;亲测用 node 14 和 16 install 会报错&#xff09; node&#xff1a;20.9.0 npm&#xff1a;10.1.0 2、初始化项目 npm create sveltelatest my-app cd my-app npm install npm run de…

本地部署、微调大模型

本地部署、微调大模型 一、本地部署大模型 1.部署 更新git-lfs apt-get updateapt-get install git-lfs2. 这里极容易出错&#xff0c;如果报错就初始化git git lfs install git init git lfs install3.下载ChatGLM-6B源代码 git clone https://github.com/THUDM/ChatGLM…

华为强制恢复出厂设置后如何恢复数据?数据重生的2个方法介绍

华为作为全球知名的手机品牌&#xff0c;其产品在市场上广受欢迎。然而&#xff0c;有时由于各种原因&#xff0c;我们可能需要强制恢复出厂设置&#xff0c;这往往意味着数据的丢失。那么&#xff0c;如何在华为强制恢复出厂设置后&#xff0c;让数据“重生”呢&#xff1f;本…

赋能安防摄像头云台:国产大功率机壳开关旭之源电源可靠、高效的优势

由GIS地图、图像采集、传输、控制、显示等设备和控制软件组成的“天网系统”通过对固定区域进行实时监控和信息记录&#xff0c;为社会治安和城市管理提供了强有力的支撑。 随着技术的不断革新和升级&#xff0c;天网技术逐渐拓展到全国范围&#xff0c;并在各个城市和乡村实现…

兼容浏览器,切换PC端显示PC端,切换H5端显示H5端

兼容浏览器&#xff0c;切换PC端显示PC端&#xff0c;切换H5端显示H5端 Uniapp vue3 Uview 项目 Vue3 Vite Ts ElementPlus PC端 &#xff08;在浏览器PC端&#xff0c;切换H5端兼容显示H5端页面&#xff09; 浏览器H5端 (在浏览器H5端&#xff0c;切换PC端兼容显示PC端…

【React】通过实际示例详解评论列表渲染和删除

文章目录 一、引言二、初始状态与状态更新1. 使用useState钩子管理状态2. 评论列表的初始数据 三、列表渲染的实现1. list.map(item > { ... })2. return 语句3. JSX 语法4. 为什么这样设计5. 完整解读 四、列表项的唯一标识1. key 的作用2. key 的用法3. 可以没有 key 吗&a…

SpringBoot整合Kaptcha实现图片验证码加减乘除

目录 SpringBoot整合Kaptcha实现图片验证码加减乘除1. 添加Kaptcha依赖2. 自定义文本生成器3. 配置Kaptcha4. 获取验证码图片的方法4.1. 详细讲解控制器中的切割操作 5. 总结 SpringBoot整合Kaptcha实现图片验证码加减乘除 在开发Web应用时&#xff0c;验证码是一个常见的功能…

Dhtmlx Gantt教程:创建交互式甘特图的完整指南

在现代的项目管理中&#xff0c;时间是一种宝贵的资源&#xff0c;而甘特图则是一把解锁项目进度的魔法钥匙&#xff0c;想象一下&#xff0c;您可以在一个直观而动态的时间轴上&#xff0c;清晰地看到项目的每一个任务如何交织在一起&#xff0c;如何随着时间的推移展开&#…

temu卖家中心入口登入在哪里,跨境电商temu卖家中心入口登入

在跨境电商的浪潮中&#xff0c;拼多多推出的Temu平台以其独特的商业模式和优惠政策&#xff0c;吸引了众多卖家的目光。对于想要入驻Temu平台的商家而言&#xff0c;找到正确的卖家中心入口并成功登录&#xff0c;是开启跨境电商之旅的第一步。那么&#xff0c;Temu卖家中心入…

QGC二次开发入门教程(一):课程大纲

文章目录 前言一、课程大纲二、修改软件名称三、修改软件图标四、官方QGC中文版BUG修复五、汉化六、修改商标七、添加信号-槽1、添加文件到QGC工程2、添加界面3、QML和C交互4、信号与槽5、测试 八、添加QML和C交互九、MAVLINK的解析与发送十、换地图十一、添加自定义mavlink消息…