C语言-第十八周做题总结-数组3

id:454 A.字符串逆序

题目描述

输入一个字符串,对该字符串进行逆序,输出逆序后的字符串。

输入

输入在一行中给出一个不超过80个字符长度的、以回车结束的非空字符串。

输出

在一行中输出逆序后的字符串。

输入样例

在这里插入图片描述

输出样例

在这里插入图片描述

题解

  • 先用一个while循环持续输入字符
  • 如果输入的字符为换行符,则退出循环,若不是,则将字符赋值给数组
  • 因为最后一个字符为’\0’,所以for循环的起始下标是倒数第二个,每次循环下标减一,直到下标小于0

代码

#include <stdio.h>
#include <stdlib.h>
# define MAX 80int main(int argc, char *argv[])
{int i, j;char ch, a[MAX];i = 0;while (ch = getchar()){if (ch == '\n'){break;}a[i] = ch;i++;}for (j = i - 1; j >= 0; j--){printf("%c", a[j]);}return 0;
}

id:452 B.查找指定字符

题目描述

本题要求编写程序,从给定字符串中查找某指定的字符。

输入

输入的第一行是一个待查找的字符。第二行是一个以回车结束的非空字符串(不超过80个字符)。

输出

如果找到,在一行内按照格式“index = 下标”输出该字符在字符串中所对应的最大下标(下标从0开始);否则输出"Not Found"。

输入样例

在这里插入图片描述

输出样例

在这里插入图片描述

题解

  • 先输入要查找的字符,然后要注意此时输入了一个换行符,也是字符,要用getchar();把它舍弃
  • 然后用一个while循环持续读入字符,将读入的字符赋值给数组,如果读入的字符为换行符,则结束循环
  • 接着用for循环来查找字符串中所要查找的字符,遍历整个数组,看是不是有相等的,若有,则将此下标赋值给一个变量,若之后又出现相同的字符,则可更新这个变量的值,若这个变量的值没有改变,即还是赋初值,则输出Not Found,否则,输出这个最大的下标

代码

#include <stdio.h>
#include <stdlib.h>
# define MAX 80int main(int argc, char *argv[])
{int i, t;char n, ch, a[MAX];i = 0;t = 0;scanf("%c", &n);getchar();while (ch = getchar()){a[i] = ch;i++;if (ch == '\n')	{break;}}for (i = 0; a[i] != '\n'; i++){if (a[i] == n){t = i;}}if (t == 0){printf("Not Found");}else{printf("index = %d", t);}return 0;
}

id:781 C.凯撒密码

题目描述

为了防止信息被别人轻易窃取,需要把电码明文通过加密方式变换成为密文。输入一个以回车符为结束标志的字符串(少于80个字符),再输入一个整数offset,用凯撒密码将其加密后输出。恺撒密码是一种简单的替换加密技术,将明文中的所有字母都在字母表上偏移offset位后被替换成密文,当offset大于零时,表示向后偏移;当offset小于零时,表示向前偏移。

输入

输入第一行给出一个以回车结束的非空字符串(少于80个字符);第二行输入一个整数offset。

输出

输出加密后的结果字符串。

输入样例

在这里插入图片描述

输出样例

在这里插入图片描述

题解

  • 用一个while循环用来持续读入不是换行符的字符,并将其赋值给数组
  • 然后读入偏移量,再用一个for循环来将数组的字符都进行偏移
  • 分为两种情况,字符为大写字母和小写字母,若为大写字母,又分为两种情况,偏移量大于零和小于零,若偏移量大于零,则将每个数组的值改变为,将原本数组的值减去字符A的得到的是与字符A的偏差,然后将这个偏差值加上偏移量,再将这个和求余26,将所得的值加上字符A极为偏移后的新的字符;若偏移量小于零,将原本数组的值减去字符A的得到的是与字符A的偏差,然后将这个偏差值加上偏移量,再加上26(因为a的后面是z),将这个和求余26,将所得的值加上字符A极为偏移后的新的字符。小写字母的处理方法雷同
  • 最后用循环来输出字符串,循环的条件是数组的值不为’\0’

代码

#include <stdio.h>
#include <stdlib.h>
# define MAX 80int main(int argc, char *argv[])
{int offset, i;char a[MAX], ch;i = 0;while ((ch = getchar()) != '\n'){a[i] = ch;i++;}scanf("%d", &offset);for (i = 0; a[i] != '\0'; i++){if (a[i] >= 'A' && a[i] <= 'Z'){if (offset >= 0){a[i] = 'A' + (a[i] - 'A' + offset) % 26;}else{a[i] = 'A' + (a[i] - 'A' + offset + 26) % 26;}}else if (a[i] >= 'a' && a[i] <= 'z'){if (offset > 0){a[i] = 'a' + (a[i] - 'a' + offset) % 26;}else{a[i] = 'a' + (a[i] - 'a' + offset + 26) % 26;}}}for (i = 0; a[i] != '\0'; i++){printf("%c", a[i]);}return 0;
}

id:448 D.输出大写英文字母

题目描述

本题要求编写程序,顺序输出给定字符串中所出现过的大写英文字母,每个字母只输出一遍;若无大写英文字母则输出“Not Found”。

输入

输入为一个以回车结束的字符串(少于80个字符)。

输出

按照输入的顺序在一行中输出所出现过的大写英文字母,每个字母只输出一遍。若无大写英文字母则输出“Not Found”。

输入样例

在这里插入图片描述

输出样例

在这里插入图片描述

题解

  • 先定义两个变量,一个用于存储输入的变量,一个用于存储已经输出的变量
  • 首先用while循环持续输入不是换行符的字符,然后赋值给数组
  • 然后用一个for循环来遍历整个数组,循环的条件是这个数组的值不是\0,接着用一个判断语句判断这个数组的字符是不是大写字母
  • 若是,则再用一个for循环,这个循环的目的是遍历整个用于存储输出过的字符的数组,若输入的字符与输出过的字符相等,则结束循环,并让表示这两个数组的字符相等的变量值变为1(赋初值为0),若这个变量为0,则表示这个数组的值没有输出过,则将这个数组的值赋值给表示输出过的字符的数组,并将这个字符输出,然后让表示这个字符串中存在有大写字母的变量赋值为1(赋初值为0),然后将表示这个字符与输出过的数组的字符相等的变量重新赋值为0,用于下一次判断
  • 若表示这个字符串中存在有大写字母的变量值为0,则输出Not Found
  • 注意:需要将表示输出过的字符的数组赋值为0,需要用到一个头文件

代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
# define MAX 80int main(int argc, char *argv[])
{int i, j, k, x, y;char a[MAX], b[MAX], ch;memset(b, 0, sizeof(b));i = 0;j = 0;k = 0;x = 0;y = 0;while ((ch = getchar()) != '\n'){a[i] = ch;i++;}for (i = 0; a[i] != '\0'; i++){if (a[i] >= 'A' && a[i] <= 'Z'){for (k = 0; b[k] != '\0'; k++){if (a[i] == b[k]){y = 1;break;}}if (y == 0){b[j] = a[i];printf("%c", a[i]);j++;x = 1;}y = 0;}}if (x == 0){printf("Not Found");}return 0;
}

id:447 E.删除重复字符

题目描述

本题要求编写程序,将给定字符串去掉重复的字符后,按照字符ASCII码顺序从小到大排序后输出。

输入

输入是一个以回车结束的非空字符串(少于80个字符)。

输出

输出去重排序后的结果字符串。

输入样例

在这里插入图片描述

输出样例

在这里插入图片描述

题解

  • 先定义两个数组,一个数组用于存储输入的字符串,一个数组用于存储已经输出过的字符串
  • 用for循环处理字符串的输入并赋值给数组,循环的条件是输入的字符不是换行符,循环内部是空语句,所以用一个分号即可,循环结束后,将\0赋值给输入完字符串后下一个数组
  • 接着再用一个for循环,目的是遍历整个字符串数组,循环的条件是数组的字符不是\0,定义一个变量表示字符串中的最小值,让这个最小值赋初值为127(因为127是ASCII码表中的最大值),再用一个for循环用来将整个字符串中的字符与当前字符做对比,定义一个用来表示当前字符没有被输出过的变量,赋初值为0,然后再用一个for循环,目的是遍历整个表示已经输出过的字符的数组,在这个循环中,判断当前字符是否已经被输出过,若是,则将表示这个已经被输出过的变量赋值为1,然后结束当前循环,接着判断用于表示当前字符是否被输出过的变量的值是否改变(值为1)以及当前变量是否小于最小值,若这个字符没有被输出过,且这个字符小于最小值,则更新这个最小值,赋值为当前字符
  • 遍历完整个目的是对比整个数组后,得到的最小值的字符会被成功赋值到表示最小值的变量中,如果这个变量不等于127,则输出这个变量,然后将这个变量复制到表示已经输出过的数组中,便于下次遇到相同的字符时不再输出

代码

#include <stdio.h>
#include <stdlib.h>
# define MAX 80int main(int argc, char *argv[])
{int i, k, x, y, j;char a[MAX], b[MAX], ch, min;x = 0;for (i = 0; (a[i] = getchar()) != '\n'; i++){;}a[i] = '\0';for (k = 0; a[k] != '\0'; k++){min = 127;for (i = 0; a[i] != '\0'; i++){y = 0;for (j = 0; j < x; j++){if (a[i] == b[j]){y = 1;break;}}if (y != 1 && min > a[i]){min = a[i];}}if (min != 127){printf("%c", min);b[x] = min;x++;}}return 0;
}

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

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

相关文章

【多线程】

文章目录 一、线程与进程的概念&#xff1a;二、多线程实现三、线程锁四、线程数量的设置 一、线程与进程的概念&#xff1a; 简单理解 假设总共有3个孩子需要喂饭&#xff0c;孩子每吃一口饭需要咀嚼消化一下。 多线程方案&#xff1a; 雇佣1个保姆&#xff0c;在喂A孩子吃饭…

人机之间的联系

人机之间的联系指的是人类和机器之间的交互和合作关系。人机联系的目的是通过利用机器的计算能力和人类的智能能力来实现更高效、更准确的工作和决策。 人机之间的看得见的链接&#xff0c;是指人与机器之间通过视觉、听觉等感官传递信息的方式&#xff0c;如人与电脑之间通过显…

生成式AI在自动化新时代中重塑RPA

生成式AI的兴起正在推动行业的深刻变革&#xff0c;其与RPA技术的结合&#xff0c;标志着自动化领域新时代的到来。这种创新性结合极大地提升了系统的适应性&#xff0c;同时也推动了高级自动化解决方案的发展&#xff0c;为下一代RPA的诞生奠定了坚实的基础。 核心RPA技术专注…

使用Java构建RESTfulWeb服务

构建RESTful Web服务是一种常见的Web开发方法&#xff0c;它提供了一种简单、可扩展和易于使用的方式来设计和实现Web API。Java作为一种强大而广泛使用的编程语言&#xff0c;提供了多种工具和框架来构建RESTful Web服务。在本文中&#xff0c;我将介绍如何使用Java构建RESTfu…

基础面试题整理2

1.抽象类与接口区别 语法&#xff1a; 抽象类用abstract定义&#xff1b;接口用interface定义抽象类被子类继承extends&#xff08;不可用final修饰&#xff09;&#xff1b;接口被类实现implements抽象类的属性访问无限制,方法不可用private修饰&#xff1b;接口中的方法只能…

BRC20 技术分析

文章目录 什么是 BRC20 ?brc20 白皮书。重点基于链上数据解析获取交易详情返回值如何将 16 进制转换为 字符串没有节点,如何获取数据?见证隔离如何解析出 BRC20 数据?最后如何快速搭建节点BRC20 Indexer

[C#]使用sdcb.paddleocr部署v4版本ocr识别模型

【官方框架地址】 https://github.com/sdcb/PaddleSharp 【算法介绍】 PaddleOCR&#xff0c;全称为PaddlePaddle OCR&#xff0c;是PaddlePaddle深度学习平台下的一款强大的光学字符识别工具。它利用深度学习技术&#xff0c;实现了高精度的文字识别&#xff0c;可以帮助用户…

计数器的LED显示控制电路图

如图所示&#xff0c;图a中采用十进制七段存储-译码-驱动单元74143,此单元对所有段都有恒流输出。在电压为5V时每段电流约为15~22mA.七段译码器的BCD数据可以由脚17~20上取出。脚22用于进位&#xff0c;即当计数值到9后就为低电平&#xff0c;其余为高电平。利用这个信号可以控…

Eureka工作原理及代码实例

Eureka是Netflix开源的一个服务发现框架&#xff0c;它的作用是让分布式系统中的服务实例能够自动注册和发现。本篇博客将详细介绍Eureka的工作原理及其组件。 1、Eureka的基础组件 Eureka包含两个基本组件&#xff1a;Eureka Server和Eureka Client。Eureka Server为服务注册…

测试:Fuzz测试

简介 Fuzz测试&#xff08;Fuzz Testing&#xff09;是一种软件测试技术&#xff0c;其核心思想是向系统输入大量异常、随机生成的数据&#xff08;称为“模糊数据”或“fuzz”&#xff09;&#xff0c;以此触发系统潜在的错误或漏洞&#xff0c;如崩溃、安全漏洞、性能问题等…

Python:isalpha() 和 isalnum() 区别

isalpha() 和 isalnum() 是 Python 中的字符串方法&#xff0c;用于判断字符串是否仅包含特定类型的字符。下面我会逐个介绍这两个函数的语法结构、参数含义、使用举例和适用场景&#xff0c;并解释它们之间的区别。 一、isalpha() 语法结构&#xff1a;string.isalpha() 参数…

Matlab:遗传算法,模拟退火算法练习题

1、遗传算法 &#xff08;1&#xff09;遗传算法是一种基于自然选择原理和自然遗传机 制的搜索&#xff08;寻优&#xff09;算法&#xff0c;它是模拟自然界中的生命进化机制&#xff0c;在人工系统中实现特定目 标的优化。遗传算法的实质是通过群体搜索技术&#xff0c;根据…

神经网络中的重要概念

神经网络是一种模拟生物神经网络结构和功能的计算模型&#xff0c;由许多节点&#xff08;或称为神经元&#xff09;和它们之间的连接构成。以下是一些神经网络中的重要概念&#xff0c;并对它们进行细致的讲解&#xff1a; 神经元&#xff08;Neuron&#xff09;&#xff1a;神…

捕捉“五彩斑斓的黑”:锗基短波红外相机的多种成像应用

红外处于人眼可观察范围以外&#xff0c;为我们了解未知领域提供了新的途径。红外又可以根据波段范围&#xff0c;分为短波红外、中波红外与长波红外。较短的SWIR波长——大约900nm-1700nm——与可见光范围内的光子表现相似。虽然在SWIR中目标的光谱含量不同&#xff0c;但所产…

Debezium发布历史51

原文地址&#xff1a; https://debezium.io/blog/2019/03/14/debezium-meets-quarkus/ 欢迎关注留言&#xff0c;我是收集整理小能手&#xff0c;工具翻译&#xff0c;仅供参考&#xff0c;笔芯笔芯. Debezium 遇见 Quarkus 三月 14, 2019 作者&#xff1a; Jiri Pechanec qu…

瓢虫目标检测数据集VOC格式400张

瓢虫&#xff0c;一种小巧玲珑、色彩鲜艳的昆虫&#xff0c;因其独特的形态和生态习性而受到广泛欢迎。 瓢虫的体型小巧&#xff0c;一般为圆球形&#xff0c;体色鲜艳&#xff0c;有红、黄、黑等多种颜色。它们通常有一个坚硬的外壳&#xff0c;可以保护自己不受天敌的侵害。…

Spark回归分析与特征工程

回归分析是统计学和机器学习中的一个重要分支&#xff0c;用于建立因变量与自变量之间的关系模型。在大数据领域&#xff0c;Apache Spark为回归分析提供了强大的工具和库&#xff0c;以处理大规模数据集。本文将深入探讨如何使用Spark进行回归分析以及如何进行特征工程&#x…

AtomicReference自旋加CAS保证对象引用原子性

AtomicReference类提供了对象引用的非阻塞原子性读写操作&#xff0c;并且提供了其他一些高级的用法&#xff0c;对象的引用其实是一个4字节的数字&#xff0c;代表着在JVM堆内存中的引用地址&#xff0c;对一个4字节数字的读取操作和写入操作本身就是原子性的 package Atomic…

【微服务合集】

文章目录 MyBatisPlusMyBatisPlus 注解WrapperMybatisPlus批量插入(saveBatch)MyBatisPlus 分页插件 DockerDockerfileDocker网络Docker部署项目 黑马微服务文档尚硅谷SpringBoot2尚硅谷SpringBoot3 MyBatisPlus MyBatisPlus 注解 TableName TableId TableField MyBatisPlu…

冬天夺去的清爽,可爱,春天都会还给你

这款外套上身可太时尚好看了 春天日常穿着或者出行游玩 应对早晚温差&#xff0c;兼具时尚和温度两不误 干净率性闲适的洒脱范整件衣服干净不失细节 下摆有橡筋收紧更加保暖了工艺方面也毫不逊色&#xff0c;防水拉链 四合扣、猪鼻扣一应俱全简直就是一件实用与时尚并存的…