当前位置: 首页 > article >正文

CF 1896 A. Jagged Swaps 学习笔记

链接

传送门

代码

#include<bits/stdc++.h>

using namespace std;

const int N=20;

int a[N];

int main()
{
	int t;
	scanf("%d",&t);
	
	while(t--)
	{
		int n;
		scanf("%d",&n);
		
		for(int i=1;i<=n;i++)
		{
			scanf("%d",&a[i]);
		}
		
		if(a[1]==1)	printf("yes\n");
		else	printf("no\n");
		
		memset(a,0,sizeof a);
	}
	
	return 0;
}

总结

1.第一次写WA 2 ,代码如下

#include<bits/stdc++.h>
using namespace std;

const int N=20;

int a[N],b[N];

int main()
{
	int t;
	scanf("%d",&t);
	
	while(t--)
	{
		int n;
		scanf("%d",&n);
		for(int i=1;i<=n;i++)
		{
			scanf("%d",&a[i]);
			b[i]=a[i];
		}
		sort(b+1,b+1+n);
		//for(int i=1;i<=n;i++)	printf("%d ",b[i]);
		
		for(int i=2;i<=n-1;i++)
		{
			if(a[i]>a[i-1]&&a[i]>a[i+1])	swap(a[i],a[i+1]);
		}
		
		bool flag=false;
		for(int i=1;i<=n;i++)
		{
			if(a[i]!=b[i])
			{
				flag=true;
				break;
			}
		}
		
		if(flag==true)	printf("no\n");
		else	printf("yes\n");
		
		memset(a,0,sizeof a);
		memset(b,0,sizeof b);
	}
	
	return 0;
}

//permutation 排列
//arbitrary 任意的
//modified 改变
//Hence 因此
//hold 包含
//pretend 假装
//Implementation 实施

错误思路是,每遇到一个a[i]>a[i-1]&&a[i]>a[i+1]的情况,就交换a[i]和a[i+1],但事实上不是这样的,我们是有选择的交换,而不是遇到一个交换一个

2.题目说的很清楚,给定一个排列,特意解释了一下排列的意思,比如说总的元素个数是3,元素就只会是1,2,3,我刚开始还以为只是这个题目数据范围比较小

3.a[i]>a[i-1]&&a[i]>a[i+1],i>=2&&i<=n-1,我们可以发现,第一个数字是无法移动的,所以第一个数字必须是数字1

4.有选择的进行交换操作:首先交换最大的数字,把最大的数字移动到排列的最后面,然后移动倒数第二大的数字,循环操作,直到排列完成,所以说只要第一个数字等于1,后面的数字都可以排列好,只需要判断第一个数字是否为1该题就可以解决


http://www.kler.cn/a/147344.html

相关文章:

  • L11.【LeetCode笔记】有效的括号
  • 阮一峰科技爱好者周刊(第 325 期)推荐工具:一个基于 Next.js 的博客和 CMS 系统
  • 终端快捷键学习笔记
  • 量化交易系统开发-实时行情自动化交易-3.4.3.3.期货市场深度数据
  • 【操作系统不挂科】<Linux进程概念(4)>选择题(带答案与解析)
  • C++创建型设计模式体现出的面向对象设计原则
  • 【STM32】GPIO输入
  • Android Bitmap 模糊效果实现 (二)
  • 渠道运营常用的ChatGPT通用提示词模板
  • 解决几乎任何机器学习问题 -- 学习笔记(组织机器学习项目)
  • 自动化任务:探索 Shell 脚本的实际应用
  • git 无法可克隆分支 时候使用tortoisegit
  • 工具推荐 sejda pdf一个可以将pdf转为txt的工具
  • Vue基础入门(三):Vue3的使用
  • 扫地机器人市场持续火爆,景联文科技数据采集标注方案助力扫地机器人智能化升级
  • C++ Qt QVariant类型使用介绍与代码演示
  • MATLAB实战 | 不同形式的三维曲面图
  • STM32 ADC转换器、串口输出
  • 【深度学习】Transformer简介
  • wireshark 抓包提示
  • LeetCode746. Min Cost Climbing Stairs
  • Python---引用变量与可变、非可变类型
  • Ubuntu 22.03 LTS 安装deepin-terminal 实现 终端 分屏
  • 笔记二十一、使用路由search进行传递参数
  • pandas教程:时区计数 USA.gov Data from Bitly USA.gov数据集
  • 反爬虫机制与反爬虫技术(二)