C语言日常练习 Day17

server/2024/9/20 7:06:04/ 标签: c语言, 算法, 开发语言

目录

一、找出一个二维数组的鞍点

二、有一篇文章,共有3行文字,每行有80个字符。要求分别统计出其中的英文大写字母、小写字母、数字、空格以及其他字符的个数

三、有一行电文,已按下面规律编译成密码:A->Z,a->z,B->Y,b->y,即第1个字母变成第26个字母,第i个字母变成第(26-i+1)个字母,非字母字符不变。要求编程将密码译回原文,并输出密码和原文。


一、找出一个二维数组的鞍点

即该位置上的元素在该行上最大、在该列上最小,也可能没有鞍点。

  1. 先找出每行最大的值
  2. 再比较每行最大的值是否是该列最小的值

代码如下:

#include<stdio.h>int main()
{int arr[20][20];int n,m;scanf("%d %d",&n,&m);int i,j,count=0,max;int temp_i,temp_j;for(i=0;i<n;i++){for(j=0;j<m;j++){scanf("%d",&arr[i][j]);}}for(i=0;i<n;i++){max=arr[i][0];for(j=0;j<m;j++){if(max<arr[i][j]){max=arr[i][j];temp_j=j;}}//判断arr[i][temp_j]是否是arr[0][temp_j]...... arr[k][temp_j]中最小的int flag=1;int k;for(k=0;k<n;k++){if(arr[k][temp_j]<max){flag=0;break;}}if(flag==1){printf("坐标为(%d,%d)的值:%d是鞍点\n",i,temp_j,arr[i][temp_j]);count++;}}if(count==0){printf("404not found\n");}return 0;
}

运行结果如下:

 

二、有一篇文章,共有3行文字,每行有80个字符。要求分别统计出其中的英文大写字母、小写字母、数字、空格以及其他字符的个数

代码如下:

#include<stdio.h>int main()
{char arr[3][80]={0};int i,j;int big_word=0,small_word=0,number=0,space=0,other=0;for(i=0;i<3;i++){gets(arr[i]);}for(i=0;i<3;i++){for(j=0;arr[i][j]!='\0';j++){if(arr[i][j]>='A'&&arr[i][j]<='Z'){big_word++;}else if(arr[i][j]>='a'&&arr[i][j]<='z'){small_word++;}else if(arr[i][j]==" "){space++;}else if(arr[i][j]>='0'&&arr[i][j]<='9'){number++;}else{other++;}}}printf("大写字母:%d,小写字母:%d,数字:%d,空格:%d,其他字符:%d",big_word,small_word,number,space,other);return 0;
}

测试用例:

??123
ABCnihao
>>

运行结果如下(如果输入的是中文输入法下的其他字符,比如:?其他字符会记数为2)

 

三、有一行电文,已按下面规律编译成密码:A->Z,a->z,B->Y,b->y,即第1个字母变成第26个字母,第i个字母变成第(26-i+1)个字母,非字母字符不变。要求编程将密码译回原文,并输出密码和原文。

题目的关键在于解密,解密的表达式我们可以写为'A' + (25 - (s[i] - 'A'))

让我们分解这个表达式来理解它是如何工作的:

  1. s[i] - 'A':这个子表达式计算当前字符 s[i] 与大写字母 'A' 之间的ASCII码差值。因为ASCII码是连续的,并且 'A' 的ASCII码是65,所以如果 s[i] 是 'B',那么 s[i] - 'A' 的结果就是 1(因为 'B' 的ASCII码是66)。

  2. 25 - ...:然后,从这个差值中减去 25。这是因为加密规则是将第 i 个字母映射到第 26-i+1 个字母。但是,由于我们已经通过 s[i] - 'A' 得到了从 0 开始的索引(对于 'A' 是 0,'B' 是 1,依此类推),我们需要做的是找到这个索引对应的“反向”索引。由于字母表有 26 个字母,所以 25 - (s[i] - 'A') 实际上是在计算从 'Z' 开始往回数的位置。

  3. 'A' + ...:最后,我们将上一步的结果加上 'A' 的ASCII码。这是因为我们想要得到的是解密后的大写字母的ASCII码。由于我们已经计算出了从 'Z' 往回数的位置,加上 'A' 的ASCII码就会将我们带回到字母表的正确位置。

举个例子,如果 s[i] 是 'Z'(ASCII码为90),那么:

  • s[i] - 'A' = 90 - 65 = 25
  • 25 - 25 = 0
  • 'A' + 0 = 'A'

所以,'Z' 被正确地解密回 'A'。

 代码如下:

#include<stdio.h>
int main()
{char s[100]={0};gets(s);printf("password is:%s\n", s);int i;while(s[i]){if(s[i]>='a'&&s[i]<='z'){s[i]='a' + (25 - (s[i] - 'a')) ;}else if(s[i]>='A'&&s[i]<='Z'){s[i]='A'+(25-(s[i]-'A') );}i++;}printf("original text is :%s",s);return 0;
}

运行结果如下:

测试用例:

I am 


http://www.ppmy.cn/server/102059.html

相关文章

wordpress视频模板

视频背景wordpress官网主题 红色风格的wordpress主题&#xff0c;首页视频背景&#xff0c;鼠标滚动翻转展示内容&#xff0c;适合公司官网使用。 https://www.jianzhanpress.com/?p7288 MCN传媒wordpress主题 红色风格wordpress大视频背景主题&#xff0c;适合做直播业务的…

【Harmony OS 4.0】水果排行榜案例

ets/example2/Models export class FruitsData {id: stringname: stringvote: stringconstructor(id: string, name: string, vote: string) {this.id idthis.name namethis.vote vote} }ets/example2/TitleComponent // app标题子组件 import APPContext from ohos.app.a…

【ARM 芯片 安全与攻击 5.4 -- Meltdown 攻击与防御介绍】

文章目录 什么是 Meltdown 攻击?Meltdown 攻击的基本原理Meltdown 攻击代码示例Meltdown 攻击在芯片中的应用应用场景Meltdown 攻击与瞬态攻击、测信道攻击的关系针对 Meltdown 攻击的防御硬件级防御Summary什么是 Meltdown 攻击? Meltdown 攻击是一种利用处理器乱序执行(o…

【网络编程】组播的实现(C语言,linux,Ubuntu)

组播 1> 组播也是实现一对多的通信方式&#xff0c;对于广播而言&#xff0c;网络需要对每个消息进行复制转发&#xff0c;会占用大量的带宽&#xff0c;导致网络拥塞 2> 组播可以实现小范围的数据传播&#xff1a;将需要接收数据的接收端加入多播组&#xff0c;发送端…

Linux---05---用户组权限

课程回顾 vim编辑器 本章重点 文件权限 用户管理 用户组管理 一、文件权限 由于Linux是一个多人多任务的系统&#xff0c;因此经常会出现同一台机器同时有多个人进行操作&#xff0c;为了考虑每个人的隐私权以及每个人喜好的工作环境&#xff0c;所以文件的权限归属就至关…

50Kg大载重六旋翼无人机技术详解

50Kg大载重六旋翼无人机的机体结构设计是确保其高承载能力和飞行稳定性的基础。该机体通常采用轻质高强度的材料如碳纤维、铝合金或复合材料构建&#xff0c;以在保证结构强度的同时减轻整机重量。设计过程中&#xff0c;需考虑空气动力学原理&#xff0c;优化机臂布局、机身形…

Leetcode面试经典150题-189.轮转数组

解法都在代码里&#xff0c;不懂就留言或者私信 class Solution {public void rotate(int[] nums, int k) {/**向右轮转 1 步: [7,1,2,3,4,5,6]向右轮转 2 步: [6,7,1,2,3,4,5]向右轮转 3 步: [5,6,7,1,2,3,4]....向右轮转 7 步: [1,2,3,4,5,6,7] *//**既然反转数组的倍数是不需…

oracle使用sql生成表结构文档

oracle使用sql生成表结构文档 背景 客户要求数据资产盘点,需要提供相关表字段的说明文档&#xff0c;指定具体格式。手动是不可能手动的&#xff0c; 使用SQL实现。 要求 实现 生成脚本sql 查询所有非临时表 SELECT table_name FROM all_tables WHERE temporary N;--默认…

sp-eric靶机

端口扫描 靶机ip地址为192.168.7.46 目录扫描 访问80端口 拼接访问 /admin.php 发现登录框 测试sql注入&#xff0c;弱口令等&#xff0c;无结果 扫描目录发现了.git文件&#xff0c;存在源码泄漏 将其下载到kali上读取 python2 GitHack.py -u http://192.168.7.180/.git/…

深入探索CANoe的CAPL语言

概述 在汽车电子和嵌入式系统开发领域&#xff0c;仿真和测试是确保功能正确性和性能标准的关键步骤。Vector公司的CANoe软件是这一领域的佼佼者&#xff0c;它提供了一个强大的平台&#xff0c;用于模拟、测试和分析汽车网络&#xff0c;特别是CAN网络。今天&#xff0c;我们…

无人机电池详解!!!

娱乐型和玩具型无人机 这类无人机的电池容量通常较小&#xff0c;以满足短时间娱乐飞行的需求。电池容量范围一般在500mAh至3000mAh之间&#xff0c;轻便、易携带&#xff0c;适合初学者和休闲玩家。 航拍无人机 普通航拍无人机追求高续航能力&#xff0c;电池容量一般在500…

玩转单例模式

目录 1. 饿汉式 2. 懒汉式 3. volatile解决指令重排序 4. 反射破坏单例模式 5. 枚举创建单例模式 所谓单例模式&#xff0c;就是是某个类的实例对象只能被创建一次&#xff0c;单例模式两种实现&#xff1a;饿汉式和懒汉式。 1. 饿汉式 所谓饿汉式&#xff0c;顾名思义…

Lambda表达式与流式编程

一、Lambda表达式 1.1 什么是lambda表达式 Lambda表达式是 jdk1.8 引入的一个新特性&#xff0c;它是函数式编程在Java中的一种体现。也是1.8最值得学习的新特性。 1. Lambda表达式实际上就是匿名内部类的简化版本。 2. Lambda表达式是jdk1.8引入的一个最重要的新特性&…

VUE(一)——nextTick

DOM更新循环结束后执行延迟回调&#xff0c;在数据修改以后立即使用该方法可获取更新后的DOM。 &#xff08;*问题1&#xff09;DOM更新循环&#xff1f; VUE中使用异步执行DOM更新&#xff0c;在修改数据之后视图不会立即更新&#xff0c;而是等同一事件循环中的所有数据变化…

Java后端面试题(mq相关)(day9)

目录 为什么用MQ&#xff1f; 异步 、削峰、解耦1. 异步处理2. 解耦3. 削峰填谷 Exchange类型什么是死信队列&#xff1f;如何保证消息的可靠性&#xff1f;RabbitMQ中如何解决消息堆积问题?RabbitMQ中如何保证消息有序性?如何防止消息重复消费&#xff1f;(如何保证消息幂等…

ARM——体系结构

计算机体系结构&#xff1a;冯诺伊曼 哈佛 冯诺依曼结构 冯诺依曼结构&#xff0c;也称冯诺依曼模型或普林斯顿结构&#xff0c;是根据冯诺依曼提出的存储程序概念设计的计算机体系结构。其主要特点包括&#xff1a; 存储程序&#xff1a;指令与数据都…

嵌入式 | 嵌入式 Linux 系统使用摄像头

点击上方"蓝字"关注我们 01、引言 >>> 在嵌入式 Linux 系统使用摄像头 俗话说“眼见为实”,这或许是为什么近年来摄像头在嵌入式系统上快速增长的原因。它们被用于不同的场景,如: 远程监控:典型的例子是闭路电视,监控人员在监视环境(或许你所在的大楼…

web开发环境搭配与创建javaee项目

一.web开发 (1)web开发指的是前端,后端,以及数据库进行交互&#xff0c;前端发送请求到后端&#xff0c;后端经过程序处理后到达数据库&#xff0c;最后在进行后端处理响应回前端。 (2)一次三端交互的doget或者dopost简单请求流程 (3)web开发除了需要前端,后端,数据库开发工具…

C#垃圾处理机制相关笔记

C#编程中的垃圾处理机制主要通过垃圾回收器&#xff08;Garbage Collector&#xff0c;GC&#xff09;实现自动内存管理。C#作为一种托管语言&#xff0c;其垃圾处理机制显著减轻了程序员的内存管理负担&#xff0c;与C语言等非托管语言形成鲜明对比。具体介绍如下&#xff1a;…

ElasticSearch相关知识点

ElasticSearch中的倒排索引是如何工作的&#xff1f; 倒排索引是ElasticSearch中用于全文检索的一种数据结构&#xff0c;与正排索引不同的是&#xff0c;正排索引将文档按照词汇顺序组织。而倒排索引是将词汇映射到包含该词汇的文档中。 在ElasticSearch中&#xff0c;倒排索…