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

leetcode--每日一题--822--344(使用异或来进行数据交换)

822.翻转卡片游戏

在桌子上有 n 张卡片,每张卡片的正面和背面都写着一个正数(正面与背面上的数有可能不一样)。
我们可以先翻转任意张卡片,然后选择其中一张卡片。
如果选中的那张卡片背面的数字 x 与任意一张卡片的正面的数字都不同,那么这个数字是我们想要的数字。
哪个数是这些想要的数字中最小的数(找到这些数中的最小值)呢?如果没有一个数字符合要求的,输出 0 。
其中, fronts[i] 和 backs[i] 分别代表第 i 张卡片的正面和背面的数字。
如果我们通过翻转卡片来交换正面与背面上的数,那么当初在正面的数就变成背面的数,背面的数就变成正面的数。

首先可以翻转任意卡片,如何正和反可以相同也可以不同,如果相同翻转就没有意义。
这时候选定的数不可能和正反同的数一样。
其他都有可能吗?如果正反不同,那么选的这个数就一定有一个不同,我们就可以通过翻转来满足要求。
这时候思路就出来了。

class Solution {public int flipgame(int[] fronts, int[] backs) {int n = fronts.length;HashSet<Integer> same = new HashSet<>();for (int i = 0; i < n; i++) {if (fronts[i] == backs[i]) {same.add(fronts[i]);}}int ans = 2001;for (int i = 0; i < n; i++) {if (fronts[i] < ans && !same.contains(fronts[i])) {ans = Math.min(ans, fronts[i]);}if (backs[i] < ans && !same.contains(backs[i])) {ans = Math.min(ans, backs[i]);}}return ans % 2001;}
}

344. 反转字符串

最近学到一种新的交换方式,使用异或来进行数据交换。

    public void reverseString(char[] s) {int i = 0,j = s.length-1;while(i < j){s[i] ^= s[j];s[j] ^= s[i];s[i] ^= s[j];i++;j--;}}

顺带345.反转字符串中的元音字母

    public String reverseVowels(String s) {int i = 0,j = s.length() - 1;char[] chars = s.toCharArray();while(i < j){while(i < j && isVowel(chars[i])){i++;}while(i < j && isVowel(chars[j])){j--;}if(i < j){chars[i] ^= chars[j];chars[j] ^= chars[i];chars[i] ^= chars[j];}i++;j--;}return new String(chars);}private boolean isVowel(char c) {return "aeiouAEIOU".indexOf(c) < 0;}
http://www.lryc.cn/news/114043.html

相关文章:

  • OpenStreetMap数据转3D场景【Python + PostgreSQL】
  • 动力节点|MyBatis入门实战到深入源码
  • 分布式规则引擎框架的设计
  • C#开发FFMPEG例子(API方式) FFmpeg推送udp组播流
  • nvm下载node导致npm报错无法使用
  • LeetCode 热题 100JavaScript--2. 两数相加
  • zookeeper总结
  • 【程序环境与预处理玩转指南】
  • 搭建简易syslog日志中转服务器
  • MongoDB文档-进阶使用-spring-boot整合使用MongoDB---MongoRepository完成增删改查
  • 什么是线程局部变量?
  • Jmeter响应中的乱码问题
  • MongoDB文档-进阶使用-MongoDB索引-createindex()与dropindex()-在MongoDB中使用正则表达式来查找
  • CentOS下ZLMediaKit的可视化管理网站MediaServerUI使用
  • 回归预测 | MATLAB实现POA-CNN-BiGRU鹈鹕算法优化卷积双向门控循环单元多输入单输出回归预测
  • Rust 原生支持龙架构指令集
  • 为生成式AI提速,亚马逊云科技Amazon EC2 P5满足GPU需求
  • 聊聊企业数据安全那些事~
  • 日常随笔——如何把excel题库转换为word打印格式
  • SpringCloud项目打包注意事项以及可能出错的几种情况
  • ZABBIX 6.4 Mysql数据库分表
  • 多线程-Runable和Callable的区别
  • 智慧城市规划新引擎:探秘数字孪生中的二维与三维GIS技术差异
  • Python入门自学进阶-Web框架——38、redis、rabbitmq、git
  • 论 SoC上的Linux如何拉动外部I/O
  • SpringBoot项目如何部署SSL证书 (JKS格式)
  • 成功解决:ValueError Cannot assign non-leaf Tensor to parameter ‘weight‘
  • 面试之快速学习SQL-基础增删改查语句
  • nuxt脚手架创建项目
  • 复现原型链污染漏洞