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

原地swap(inplace_swap)

inplace_swap algorithm based on exclusive-or (^)

void inplace_swap(int *x, int *y) {*y = *x ^ *y;*x = *x ^ *y;*y = *x ^ *y;
}

原理(展开为二进制计算异或即可):
0 ^ 0 = 0
0 ^ 1 = 1
1 ^ 0 = 1
1 ^ 1 = 0


reverse_array algorithm based on inplace_swap

void reverse_array(int a[], int cnt) {for (int left=0, right=cnt-1; left < right; ++left, --right)inplace_swap(&a[left], &a[right]);
}int main() {int a[] = {1,2,3,4,5,};reverse_array(a, 5);for (int i=0; i<5; ++i)printf("%d", a[i]);return 0;
}

note that:
条件是left < right,如果改为<=,则对于奇数个序列(e.g., {1,2,3,4,5})而言会得到5,4,0,2,1,原因如下:
当l=r=2时,在同一个地址执行*y = *x ^ *y;y=0(即0110 ^ 0110 = 0000),也即该地址的值为0,此后再进行*x = *x ^ *y;的时候并不是在做0110 ^ 0000 = 0110而是0000 ^ 0000 = 0000,因为此时x和y指向同一个地址;

http://www.lryc.cn/news/284612.html

相关文章:

  • 《JVM由浅入深学习九】 2024-01-15》JVM由简入深学习提升分(生产项目内存飙升分析)
  • 统计学-R语言-4.6
  • git提权
  • 实验四 SQL语言
  • 2024年简历石沉大海,别投了,软件测试岗位饱和了....
  • JS执行顺序
  • Vscode 上安装 Compilot
  • Spring集成MyBatis与MyBatis-Plus添加分页插件
  • Windows下载安装vcpkg并使用它来安装第三方库(visualstudio)
  • leetcode-2788按分隔符拆分字符串
  • 使用Ctrl+Alt+T快速打开Windows Terminal终端
  • Redis 消息队列和发布订阅
  • 去掉element-ui的el-table的所有边框+表头+背景颜色
  • 还在手动复制文章吗?教你如何一键将文章从notion同步到WordPress
  • uni-app的学习【第三节】
  • 全自动网页制作系统流星全自动网页生成系统重构版输入网页信息即可制作
  • 云轴科技ZStack位列IDC云系统软件市场教育行业TOP2
  • 从技术大会到面试舞台:程序猿的蜕变之旅!
  • VS2019+QT5.12.12+opencv+pcl1.12.1 显示点云,运行程序报错-无法定位程序输入点于链接库 如何解决?
  • Oracle-java下载、开源/商业许可证(收费、免费说明)、版本发布日志
  • docker安装 mysql 8.0.32
  • OPC UA 开源库编译方法及通过OPC UA连接西门S7-1200 PLC通信并进行数据交换
  • 【数据库学习】ClickHouse(ck)
  • Springboot之策略模式
  • HTTP 协议和 TCP/IP 协议之间有什么区别?
  • 【Effective C++】让自己习惯C++
  • 第十一章 请求响应
  • 【React】脚手架创建项目
  • 力扣70. 爬楼梯(动态规划 Java,C++解法)
  • Wpf 使用 Prism 实战开发Day13