OJ系统刷题 第十一篇(重点题)

news2025/1/9 12:46:48

13463 - 折点计数(难题!重点题!)

时间限制 : 1 秒

内存限制 : 128 MB

给定 n 个整数表示一个商店连续 n 天的销售量。 如果某天之前销售量在增长,而后一天销售量减少,则称这一天为折点,反过来如果之前销售量减少而后一天销售量增长,也称这一天为折点。 其他的天都不是折点。 如下图中,第 3 天和第 6 天是折点。

给定 n 个整数 a1,a2,…,an 表示销售量,请计算出这些天总共有多少个折点。 为了减少歧义,我们给定的数据保证:在这 n 天中相邻两天的销售量总是不同的,即 ai−1≠ai。 注意,如果两天不相邻,销售量可能相同。

输入

输入的第一行包含一个整数 n。 第二行包含 n 个整数,用空格分隔,分别表示 a1,a2,…,an。

所有评测用例满足:1≤n≤1000,每天的销售量是不超过 10000 的非负整数。

输出

输出一个整数,表示折点出现的数量。

样例

输入

7 
5 4 1 2 3 6 4 

输出

2

 答案:

#include<iostream>
using namespace std;
int main() {
	int n;
	int Flag = -1;//Falg是用来判断当前折线是处于上升还是处于下滑,1表示上升,0表示下滑
	int isFlat = -1;//isFlat用来判断折线是否是平坦,1平坦,0不平坦
	int upCount = 0, downCount = 0;
	cin >> n;
	int a[10000];
	for (int i = 0; i < n; i++) {
		cin >> a[i];
	}
	for (int i = 0; i < n-1; i++) {
		if (a[i + 1] - a[i] < 0 && Flag == 1 && isFlat == 0) {//处于上升状态,发生下滑,且当前状态不是平坦状态
			upCount++;
			Flag = 0;//突然下滑
			isFlat = 0;
		}
		else if (a[i + 1] - a[i] > 0 && Flag == 0 && isFlat == 0) {//处于下滑状态,发生上升,且当前状态不是平坦状态
			downCount++;
			Flag = 1;//突然上升
			isFlat = 0;
		}
		else if (a[i + 1] - a[i]>0) {
			Flag = 1;//正在上升
			isFlat = 0;
		}
		else if (a[i + 1] - a[i] < 0) {
			Flag = 0;//正在下滑
			isFlat = 0;
		}
		else {//a[i+1]-a[i]==0,当前是平坦状态
			isFlat = 1;
		}
	}
	int sum = upCount + downCount;
	cout << sum << endl;
	return 0;
}

分析:这个题还是有点难度的。

1、首先要判断当前折线的状态,上升,下滑,还有平坦。

2、只有上升到下滑的跳变或者下滑到上升的跳变才是折点。平坦到上升,或者平坦到下滑这个不是折点!!这也是本题测试点最后一个。我最开始没考虑到这种情况。

是否通过:

13464 - 画图(重点题,二刷!)

输出

输出一个整数,表示有多少个单位的面积被涂上颜色。

样例

输入

2 
1 1 4 4 
2 3 6 5 

输出

15

答案:

#include <iostream>
using namespace std;
#define MAX 101
int main(void)
{
	int a[MAX][MAX] = { 0 };
	int n;
	int x1, y1, x2, y2;//两个点的坐标
	cin >> n;
	for (int k = 0; k < n; k++)
	{	
		cin >> x1 >> y1 >> x2 >> y2;
		for (int i = x1; i < x2; i++) {//思考为什么这样写?
			for (int j = y1; j < y2; j++)//理解这个代码思想真的是太漂亮了
				a[i][j] = 1;
		}
	}

	int sum = 0;
	for (int i = 0; i < MAX; i++) {
		for (int j = 0; j < MAX; j++) {
			if (a[i][j] == 1)
				sum++;
		}
	}

	cout << sum<< endl;
	return 0;
}

分析:这个题难度比较大,我最开始以为要把所有矩形依次比较,然后每两两矩形分别找出重叠的矩形,最后减去这鞋重叠的正方形个数即为所求的正方形个数。但是这样把问题就复杂了很多。整道题的解法很巧妙。当只有一个正方形时:比如坐标为(1,1)和(4,4)

 这个矩形一共有9个小正方形被图色。9个小正方形被涂色,我们可以怎么表示呢?如下:

我们只需要把这些点标记为已经涂色即可。也就是横坐标i从x1起,直到x2-1,纵坐标从y1起,直到y2-1。

同理如果是两个矩形,分别对两个矩形做这样的处理,中间重叠的图形就直接用这些点表示即可。最后统计的时候只需要知道那些点坐标已经图上色就统计即可。

 是否通过:

21304 - 求矩阵的转置

时间限制 : 1 秒

内存限制 : 128 MB

二维矩阵的转置,将给定的一个二维数组(3×3)转置,即行列互换。

输入

一个3x3的矩阵

输出

转置后的矩阵

样例

输入

1 2 3
4 5 6
7 8 9

输出

1 4 7 
2 5 8 
3 6 9

答案:

#include<iostream>
using namespace std;
int main() {
	int a[3][3];
	for (int i = 0; i < 3; i++) {
		for (int j = 0; j < 3; j++) {
			cin >> a[i][j];
		}
	}
	for (int i = 0; i < 3; i++) {
		for (int j = 0; j < i; j++) {
			int temp = a[i][j];
			a[i][j] = a[j][i];
			a[j][i] = temp;
		}
	}
	for (int i = 0; i < 3; i++) {
		for (int j = 0; j < 3; j++) {
			cout << a[i][j] << ' ';
		}
		cout << endl;
	}
	return 0;
}

分析:这个题本身不难,但是下标从0计算的话还是容易有点迷惑。转置的意思就是a[i][j]和a[j][i]交换即可。

是否通过:

21305 - 寻找鞍点(重点题)

时间限制 : 1 秒

内存限制 : 128 MB

求一个5*5的矩阵的鞍点。鞍点指的是矩阵中的一个元素,它是所在行的最大值,并且是所在列的最小值。例如:在下面的例子中(第3行第0列的元素就是鞍点,值为8 )。

11 3 5 6 9

12 4 7 8 10

10 5 6 9 11

8 6 4 7 2

15 10 11 20 25

输入

输入包含一个5行5列的矩阵

输出

如果存在鞍点,输出鞍点所在的行、列及其值(题目中每个输入都只有一个鞍点);如果不存在,输出not found

样例

输入

11 3  5  6  9
12 4  7  8  10
10 5  6  9  11
8  6  4  7  2
15 10 11 20 25

输出

3 0 8

 答案:

#include<iostream>
using namespace std;
int main() {
	int a[5][5];
	//输入数据
	for (int i = 0; i < 5; i++) {
		for (int j = 0; j < 5; j++) {
			cin >> a[i][j];
		}
	}

	int max[5] = { 0 }, min[5] = { 0 };
	//分别求出每行的最大值和每列的最小值
	for (int i = 0; i < 5; i++) {
		max[i] = a[i][0];
		min[i] = a[0][i];
		for (int j = 0; j < 5; j++) {
			//求该元素所在行的最大值
			max[i] = max[i] > a[i][j] ? max[i] : a[i][j];
			//求该元素所在列的最小值
			min[i] = min[i] < a[j][i] ? min[i] : a[j][i];
		}
	}
	
	bool flag = false;//为true表示找到鞍点,为false表示矩阵中没有鞍点
	for (int i = 0; i < 5; i++) {
		for (int j = 0; j < 5; j++) {
			if (max[i] == a[i][j] && min[j] == a[i][j]) {
				flag = true;
				cout << i << ' ' << j << ' ' << a[i][j] << endl;
				break;
			}
		}
	}
	if (flag == false) {
		cout << "not found" << endl;
	}
	return 0;
}

分析:这个题还是比较难的,当时刚学习C语言的时候就有这道题,感觉是完全不会,无从下手,但是随着不断学习和练习,现在发现这道题也不是那么难。主要思路就是找到每一行的最大值和每一列的最小值。然后判断每个元素是否即等于当前所在行的最大值又等于当前所在列的最小值。则这个点就是鞍点

是否通过:

 

21306 - 杨辉三角形(重点题)

时间限制 : 1 秒

内存限制 : 128 MB

杨辉三角形,又称贾宪三角形、帕斯卡三角形,是二项式系数在三角形中的一种几何排列。杨辉三角形同时对应于二项式定理的系数。n次的二项式系数对应杨辉三角形的n + 1行。

输入

n(杨辉三角的行,1 <= n <= 20)

输出

行数为n的杨辉三角图形(数字与数字间使用空格隔开) 样例输入

样例

输入

3

输出

  1
 1 1
1 2 1

答案: 

#include<iostream>
using namespace std;
int main() {
	int n;
	cin >> n;
	int a[21][21] = { 0 };
	//计算三角形每个元素的值
	for (int i = 1; i <= n; i++) {
		a[i][1] = 1;
		a[i][i] = 1;
		for (int j = 1; j <= i - 1; j++) {
			a[i][j] = a[ i- 1][j - 1] + a[i - 1][j];
		}
	}
	//打印
	
	for (int i = 1; i <= n; i++) {
		//先打印空格
		for (int j = 1; j <= n - i; j++) {
			cout << ' ';
		}
		//打印数据
		for (int k = 1; k <= i; k++) {
			cout << a[i][k] << ' ';
		}
		cout << endl;
	}
	return 0;
}

分析:这是一个非常经典的问题,首先不要被打印的那个样式给唬住了,杨辉三角的正常形式是如下的样子:

即对每一行元素有如下:

a[i][1]=1;

a[i][i]=1; 

对其他元素有满足:

a[i][j]=a[i-1][i-1][j];

计算出三角形的值,然后按指定格式打印。对打印这个三角形我想再熟悉不过了,嵌套循环,嵌套两个循环做两个不同的事。这是之前刷打印三角形就掌握的。不理解的刷刷前面打印三角形那个题。

是否通过:

 

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

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

相关文章

玩转车载影像传输技术 ,学习Opengl与Surface渲染提升车载影像传输效果

近年来&#xff0c;随着智能化汽车的快速发展&#xff0c;车载倒车影像逐渐成为了汽车安全辅助系统的标配&#xff0c;而高清传输的倒车影像则成为了目前主流的倒车影像传输方式。在这一过程中&#xff0c;Opengl与Surface渲染技术的应用也是不可或缺的一环。 一、高清传输倒车…

E. Archaeology(纯思维)

Problem - E - Codeforces 爱丽丝买了一个刚果总理视频的订阅&#xff0c;正在看一部关于苏格兰卡特林湖的因子岛的考古发现的纪录片。考古学家发现了一本书&#xff0c;其年代和来源都不明。也许爱丽丝可以对它进行一些解释&#xff1f; 这本书包含一串字符 "a"、&…

【AI绘画】Stable Diffusion的介绍及程序示例

Stable Diffusion 1.背景2.StableD 的原理3.StableD 的应用3.1.如何使用 StableD 进行图像生成3.2 图像生成与编辑3.2.1 生成新图像3.2.2 图像编辑 1.背景 近年来&#xff0c;随着人工智能技术的发展&#xff0c;图像生成和合成技术得到了很大的发展。Stable Diffusion (Stable…

MyBatis的关联映射和缓存机制

学习目标&#xff1a; 了解数据表之间的三种关联关系了解对象之间的三种关系熟悉关联关系中的嵌套查询和嵌套结果掌握一对一关联映射掌握—对多关联映射掌握多对多关联映射熟悉Mybatis的缓存机制 文章概述&#xff1a; 前面几章介绍了MyBatis的基本用法、关联映射和动态SQL等…

CompletableFuture异步编排

CompletableFuture异步编排 1、CompletableFuture异步编排1.1 为什么需要异步编排1.2 CompletableFuture介绍1.3 创建异步对象1.4 线程串行化与并行化方法1.5 多任务组合1.6 优化商品详情页(业务代码)1.6.1 未优化之前的代码1.6.2 使用CompletableFuture异步编排1.6.3 测试功能…

Linux 下 REST 客户端的新选择:Insomnia 3.0

正在为 Linux 桌面端找一个免费的 REST 客户端&#xff1f; 别睡不着觉了&#xff01;试试 Insomnia。 这个应用是跨平台的&#xff0c;可以工作在 Linux、macOS、Windows。开发者 Gregory Schier 告诉我们他创造这个应用是为了“帮助开发者处理和 REST API 的通信”。他还说&a…

如何在Java中创建临时文件?

在Java程序中&#xff0c;有时需要创建临时文件来暂存数据或者执行某些操作。Java提供了许多方式来创建临时文件。在本教程中&#xff0c;我们将介绍如何使用Java标准库来创建临时文件。 一、使用File.createTempFile()方法 Java标准库中的File类提供了createTempFile()方法来…

设计模式--单例模式

介绍 所谓类的单例模式 就是采取一定的方法保证在整个软件系统中对某个类只能存在一个对象实例,并且该类只提供一个取得其对象实例的方法(静态方法) 比如 Hibemate的SessionFactory 它充当数据存储源的代理 并负责创建Session对象 SessionFactory并不是轻量级的 一般情况下 一个…

Java中的Map(三种双列集合万字详解)

点击可查看单列集合Set万字详解&#xff1a;其中还包含哈希解读和底层分析。 文章目录 前言一、Map1.Map集合常用的API代码演示&#xff1a;1.Map集合的基本功能2.Map集合的获取功能3.Map的getOrDefault()方法 2.Map集合的三种遍历1.键找值、值找键2.键值对3.Lambda表达式 二、…

【C++11】晦涩难懂语法系列:可变参数模板

目录 可变参数模板 1.1 概念 1.2 可变参数模板定义 1.3 参数包的展开方式 1.3.1 递归展开参数包 1.3.2 逗号表达式展开参数包 1.4 STL的emplace系列函数 可变参数模板 1.1 概念 在C语言阶段&#xff0c;我们已经接触过可变参数&#xff0c;比如scand、printf等等 这里…

9.2 回归分析

学习目标&#xff1a; 回归分析是一种广泛应用于数据分析和预测的统计方法&#xff0c;可以用来探索自变量与因变量之间的关系并进行预测。我学习回归分析&#xff0c;我会采取以下步骤&#xff1a; 学习基本概念&#xff1a;回归分析中的基本概念包括自变量和因变量、回归系数…

运放专题:运放输入端交直流混合信号隔直放大

运放输入不隔直放大 运放输入端不隔直&#xff0c;那么经过运放放大后&#xff0c;交流成分放大了&#xff0c;直流成分也被放大了。看下面的仿真&#xff1a; 交流信号为&#xff1a;振幅3V, 频率5K的正弦波&#xff0c;直流偏置为1V 可以看到&#xff0c;交流信号被放大的…

【Linux】匿名管道代码实现-mypipe

文章目录 管道介绍什么是管道&#xff1a;管道的原理管道的特点 具体代码详写创建初始文件makefile编写定义任务列表-task.hpp分阶段代码编写总代码展示: ctrlProcess.cc 编写头文件包含(如有不会,自己查谷歌)定义全局变量以解耦main,函数框架EndPoint定义creatProcess 创建管道…

Apollo配置中心使用篇

Apollo配置中心使用篇 常见配置中心对比Apollo核心概念Apollo核心特性Apollo架构设计各模块介绍服务端设计客户端设计Apollo与Spring集成的底层原理 Apollo安装安装apollo-portalconfig service和admin service部署多网卡问题解决修改Portal环境配置调整ApolloPortal配置 Apoll…

【产品设计】用户操作日志

日志记录了代码的执行过程&#xff0c;根据目的不同&#xff0c;可以分为系统日志和操作日志。 一、什么是日志 日志记录了代码的执行过程。根据目的不同&#xff0c;可分为系统日志和操作日志。 1&#xff09;系统日志 记录系统中硬件、软件和系统问题的信息&#xff0c;同…

C#基础学习--枚举器和迭代器

目录 枚举器和可枚举类型 IEnumerator 接口 IEnumerable 接口 实现 IEnumerable 和 IEnumerator的示例 泛型枚举接口 迭代器 迭代器块 使用迭代器来创建枚举器 使用迭代器来创建可枚举类型 常见迭代器模式 产生多个可枚举类型 将迭代器作为属性 迭代器实质 枚举器和可…

【分享】比ChatGPT还厉害?可以自主解决复杂任务的Auto-GPT迅速走红(内含体验地址)

哈喽&#xff0c;大家好&#xff0c;我是木易巷~ 最近木易巷在了解Auto GPT&#xff0c;今天给大家分享一下~ 自主解决复杂任务的Auto-GPT 什么是Auto-GPT&#xff1f; Auto-GPT 是一款开源 Python 应用程序&#xff0c;由开发者用户 Significant Gravitas 于 2023 年 3 月 30…

钉钉接入“通义千问”大模型,输入斜杠“/”唤起智能服务

4月18日&#xff0c;钉钉总裁叶军在2023春季钉峰会上宣布&#xff0c;钉钉正式接入阿里巴巴“通义千问”大模型&#xff0c;输入“&#xff0f;”在钉钉即可唤起 10 余项 AI 能力&#xff0c;叶军现场演示了群聊、文档、视频会议及应用开发四个场景。 现场展示中&#xff0c;只…

C++:智能指针(auto_ptr/unique_ptr/shared_ptr/weak_ptr)

为什么需要智能指针&#xff1f; C没有垃圾回收机制。 #include<iostream> using namespace std;int div() {int a, b;cin >> a >> b;if (b 0)throw invalid_argument("除0错误");return a / b; }void Func() {// 1、如果p1这里new 抛异常会如何…

网络原理数据链路层

嘿嘿,又见面了,今天为大家带来数据链路层的相关知识.这个层面的知识离咱们程序员太遥远了,我们简单介绍一下就行 1.以太网 2.认识Mac地址 3.区分Mac地址和IP地址 4.MTU 5.DNS 1.以太网 以太网是数据链路层和物理层的使用的网络,物理层用的不咋多,我们就先不讲了,直接看数…