swap() 函数实现的方法

swap()函数总结:

一、利用临时变量

  

  1.引用(交换任意类型)

template <typename T>

void swap(T& x,T& y)
{
  T tmp;
  tmp = y;
  y = x;
  x = tmp;
}

  2.泛型指针()

void swap(void* a,void* b )
{
    int tmp;
    tmp = y;
    y = x;
    x = tmp;
}

二、 不用临时变量交换

  1.数学运算

     1)乘

void swap (int& x,int& y)
{
    x=x*y;
    y=x/y;
    x=x/y;
}

    2)加

void swap(int& x,int& y)
{
    x=x+y;
    y=x-y;
    x=x-y;
}

  2.逻辑运算(相对其他的方法更高效)

void swap(int& a ,int& b)
{
x=x^y;
y=x^y;
x=x^y;
}

三、宏函数(注意不要有任何换行操作,或者使用换行符‘\’)

  

方法一:数学运算
#define swap((a),(b))  { (a)  += (b);  (b) =((a)-(b)) ; (a) = ((a)-(b));}

#define swap((a),(b)) { (a) *= (b); (b)=((a)/(b));
(a) = ((a)/(b))}

方法二:逻辑
#define swap((a),(b)) { (a) ^= (b); (b) ^= (a);(a) ^= (b);}
时间: 2024-10-10 11:16:41

swap() 函数实现的方法的相关文章

Java方法参数传递(swap函数)(转载)

Java里方法的参数传递方式只有一种:值传递.值传递,就是将实际参数值的副本(复制品)传入方法内,而参数本身不会受到任何影响. public class PrimitiveTransferTest { public static void swap(int a,int b) { int temp=a; a=b; b=temp; System.out.println("swap方法里,a的值是"+a+";b的值是"+b); } public static void m

《Effective C 》资源管理:条款25--考虑写出一个不抛出异常的swap函数

条款25考虑写出一个不抛出异常的swap函数 条款25:考虑写出一个不抛出异常的swap函数 swap是STL中的标准函数,用于交换两个对象的数值.后来swap成为异常安全编程(exception-safe programming,条款29)的脊柱,也是实现自我赋值(条款11)的一个常见机制.swap的实现如下: namespace std{ template<typename T> void swap(T& a, T& b) { T temp(a); a=b; b=temp;

关于swap函数传值的问题

#include <stdio.h> void swap(int * p3,int * p4); int main() {  int a = 9;  int b = 8;  int * p1 = &a;  int * p2 = &b;    printf("%x %x\n",p1,p2);  swap(p1,p2);    printf("%d %d\n",a,b);  printf("%d %d\n",*p1,*p2

c/c++和java实现swap函数的不同处

首先我们来看一下在c/c++中实现的swap函数 void swap ( int & a, int & b) { int Temp; temp = a; a = b; b = temp; } 那么在java中是否还能这样呢,很显然java中没有地址引用符号了. 首先我们来看下c/c++和java的区别. 本质区别 C/C++中swap功能的本质:通过传递变量地址(指针或引用)来交换变量地址中的值. Java标榜其中对C/C++一个很大的改进就是:Java对程序员屏蔽了变量地址的概念,减少指

Effective C++ 条款25 考虑写出一个不抛出异常的swap函数

1. swap是STL的一部分,后来成为异常安全性编程(exception-safe programming)(见条款29)的一个重要脊柱,标准库的swap函数模板定义类似以下: namespace std{ template<typename T> swap(T& lhs,T& rhs){ T temp(lhs); lhs=rhs; rhs=temp; } } 只要T类型支持拷贝构造以及拷贝赋值,标准库swap函数就会调用T的拷贝构造函数和拷贝构造操作符完成值的转换,但对于某

(转)谈谈C++中的swap函数

转自:http://blog.csdn.net/ryfdizuo/article/details/6435847 1,最通用的模板交换函数模式:创建临时对象,调用对象的赋值操作符. [cpp] view plain copy print? template <class T> void swap ( T& a, T& b ) { T c(a); a=b; b=c; } 需要构建临时对象,一个拷贝构造,两次赋值操作. 2,针对int型优化: [cpp] view plain co

@清晰掉 swap函数

swap函数估计是一个各种各样程序都会频繁用到的子程序,可是你知道它究竟有多少种不同的写法吗?下面我就列举我知道的几种swap函数来跟大家分享一下. (1)经典型---嫁衣法 无论是写程序还是干其他事情,一旦涉及到交换,就总是会遇到第三方.这个第三方可能是公正的监督者,也可能是一个徒为他人做嫁衣的可怜虫.在经典法的交换程序中,我们就需要有一个可怜虫来为我们提供暂时的服务.程序如下: void swap(int *a,int *b){int temp; temp=*a; *a=*b; *b=tem

【转】 谈谈C++中的swap函数

1,最通用的模板交换函数模式:创建临时对象,调用对象的赋值操作符. 1 template <class T> void swap ( T& a, T& b ) 2 { 3 T c(a); a=b; b=c; 4 } 5 需要构建临时对象,一个拷贝构造,两次赋值操作. 2,针对int型优化: 1 void swap(int & __restrict a, int & __restrict b) 2 { 3 a ^= b; 4 b ^= a; 5 a ^= b; 6

swap函数 的几种实现与比较

前沿 swap函数 用于交换 a ,b 两个数.实现方法大同小异,其中不乏有好多版本,现在就其性能和可读性略作分析.不对指出还望指正.. 探讨: 其中的函数原型是: (1) void swap(int &a,int &b);传引用 (2)void swap(int *a,int *b);传地址 下面就第二个函数原型分析,代码如下: #include <stdio.h> #include <stdlib.h> /** 使用中间变量tmp */ void swap(in