zoukankan      html  css  js  c++  java
  • [GeeksForGeeks] Reverse a string without using any temporary variables

    Given a string, reverse it without using any temporary variables.

    This problem is a variation of the problem swapping two integers without using any temporary variables by XOR.

    For integers x and y, to swap them using XOR, we do the following.

    x = x ^ y;

    y = y ^ x;

    x = x ^ y;

    Proof of correctness.

    y = y ^ (x ^ y) = (y ^ y) ^ x = 0 ^ x = x;

    x = (x ^ y) ^ x = (x ^ x) ^ y = 0 ^ y = y;

    QED.

    Apply this 3 steps XOR operations to each pair of characters that need to be swapped.

     1 public class Solution {
     2     public char[] reverseString(char[] str, int start, int end){
     3         while(start < end){
     4             str[start] ^= str[end];
     5             str[end] ^= str[start];
     6             str[start] ^= str[end];
     7             start++;
     8             end--;
     9         }
    10         return str;
    11     }
    12 }
  • 相关阅读:
    socket:套接字
    hashlib 加密
    面向对象总结
    类的内置方法
    反射
    类中的三个装饰器方法
    text
    模块
    练习1
    内置函数
  • 原文地址:https://www.cnblogs.com/lz87/p/7220161.html
Copyright © 2011-2022 走看看