自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

教你幾個(gè) Java 中的技巧,你會(huì)幾個(gè)?

開(kāi)發(fā) 前端
swap(x, y) 操作大家都知道,就是交互 x 和 y 的值,比如 x = 3, y = 4; 在經(jīng)過(guò) swap 操作過(guò)后,x = 4,y = 3;我們這里的問(wèn)題是如何在不使用臨時(shí)變量的情況下,只有一行代碼來(lái)實(shí)現(xiàn)這個(gè)方法。

枯燥的編程中總得有些樂(lè)趣,今天我們不談?wù)撃切└呱畹募寄埽棠銕讉€(gè)在編程中的奇技淫巧,說(shuō)不定在某些時(shí)候還能炫耀一番呢。

1.找到最大值和最小值

不使用 if else switch 和三元運(yùn)算符,在給定的三元組中找到最大值和最小值:比如給定 3,14,8,在不使用 if else switch 和三元運(yùn)算符的情況下找到最大值和最小值。

話不多說(shuō),我們先看代碼:

public static int findMax(int a, int b, int c) {
int max = a;
boolean b1 = (max < b) && ((max = b) > 0);
b1 = (max < c) && ((max = c) > 0);
return max;
}

public static int findMin(int a, int b, int c) {
int min = a;
boolean b1 = (min > b) && ((min = b) > 0);
b1 = (min > c) && ((min = c) > 0);
return min;
}

這里我們主要使用了&& 運(yùn)算符的短路特性,短路特性是指當(dāng) && 前一個(gè)表達(dá)式為 true 的時(shí)候才會(huì)繼續(xù)執(zhí)行下一個(gè)表達(dá)式,當(dāng)前一個(gè)表達(dá)式為 false 則不會(huì)執(zhí)行下一個(gè)表達(dá)式。所以在這里只有當(dāng)前一個(gè)表達(dá)式為 true 的時(shí)候,后面的賦值語(yǔ)句才會(huì)被執(zhí)行到。

我們運(yùn)行一下結(jié)果如下:

上面的這種方式入?yún)⑦m合正數(shù)和負(fù)數(shù),如果當(dāng)我們的入?yún)⒛艽_定為正數(shù)的時(shí)候,我們還可以使用下面的這種方式來(lái)實(shí)現(xiàn)。

public static int findPositiveMax(int a, int b, int c) {
int max = 0;
while (a > 0 || b > 0 || c > 0) {
a--;
b--;
c--;
max++;
}
return max;
}

public static int findPositiveMin(int a, int b, int c) {
int min = 0;
while (a > 0 && b > 0 && c > 0) {
a--;
b--;
c--;
min++;
}
return min;
}

上面的這種寫法相信大家都能看懂,阿粉就不過(guò)的解釋了,同樣的這里也利用了&&和 || 運(yùn)算的短路特性,不過(guò)要注意這種形式只能在都是正數(shù)的情況下才可以。

2.不使用臨時(shí)變量交換變量

swap(x, y) 操作大家都知道,就是交互 x 和 y 的值,比如 x = 3, y = 4; 在經(jīng)過(guò) swap 操作過(guò)后,x = 4,y = 3;我們這里的問(wèn)題是如何在不使用臨時(shí)變量的情況下,只有一行代碼來(lái)實(shí)現(xiàn)這個(gè)方法。

首先大家肯定知道這里我們要使用異或運(yùn)算^,沒(méi)錯(cuò),話不多說(shuō)我們看代碼:

public static void swapByXor(int x, int y) {
System.out.println(x + ":" + y);
x = x ^ y ^ (y = x);
System.out.println(x + ":" + y);
}

運(yùn)行過(guò)后,可以看到,x 和 y 的值已經(jīng)被交換了, 這里我們要知道兩個(gè)知識(shí)點(diǎn),那就是 n ^ n = 0; n ^ 0 = n,另外a ^ b 和 b ^ a 是等價(jià)的。

當(dāng)然除了上面的異或之外,我們還可以通過(guò)下面這種方法來(lái)實(shí)現(xiàn)。

public static void swapByAddAndSub(int x, int y) {
System.out.println(x + ":" + y);
x = x + y - (y = x);
System.out.println(x + ":" + y);
}

public static void swapByMulAndDiv(int x, int y) {
System.out.println(x + ":" + y);
x = (x * y) / (y = x);
System.out.println(x + ":" + y);
}

這兩種方式都是同樣的邏輯,先求和再減去其中一個(gè)值和先求積再除以一個(gè)值,就可以得到兩個(gè)替換后的值。

3.兩個(gè)數(shù)相乘

接下來(lái)我們?cè)倏匆粋€(gè),求兩個(gè)數(shù)的積,但是不能用乘號(hào)*。在看代碼之前,我們先分析一下,比如說(shuō)我們要求積 3 * 5 可以將 3 * 5 看成 3 * 4 + 3,也就是 (3 * 3 + 3) + 3,看到這個(gè)可能有的小伙伴已經(jīng)知道我們要怎么計(jì)算了,沒(méi)錯(cuò),那就是我們可以用遞歸。

public static int mulWithoutMul(int x, int y) {
if (y == 0)
return0;
if (y > 0)
return (x + mulWithoutMul(x, y - 1));
return -mulWithoutMul(x, -y);
}

通過(guò)上面的遞歸,我們就可以實(shí)現(xiàn)兩個(gè)數(shù)相乘但是沒(méi)有使用乘號(hào)了。

4.不使用乘號(hào)計(jì)算乘以 15

如果我們要計(jì)算一個(gè)數(shù)乘以 15 的時(shí)候,我們可以通過(guò)下面這種方式來(lái)計(jì)算,(n << 4) - n, 因 n * 15 = n * 16 - n = (n << 4) - n;同樣的如果我們某些時(shí)候要計(jì)算乘以 2 或者除以 2 的時(shí)候,我們也可以換成移位操作,n * 2 = n << 1;n / 2 = n >> 1,如果是 4 的話就可以左移 2 位或者右移 2 位,即 n * 4 = n << 2;n / 4 = n >> 2;一次類推。

使用移位的方式,在某些極端的場(chǎng)景可以提升性能。

責(zé)任編輯:武曉燕 來(lái)源: Java極客技術(shù)
相關(guān)推薦

2021-11-29 11:11:45

SQL查詢技巧

2009-06-17 15:38:57

java軟件安裝

2022-11-16 09:04:36

SQL查詢SELECT

2022-07-18 08:08:16

Go?語(yǔ)言技巧

2021-03-12 10:12:09

etState函數(shù)React

2021-06-01 05:16:49

前端開(kāi)發(fā)技術(shù)熱點(diǎn)

2019-04-15 13:24:31

2020-02-23 23:29:07

Python編程開(kāi)發(fā)

2019-10-30 16:03:48

JavaJava虛擬機(jī)數(shù)據(jù)庫(kù)

2023-11-23 10:21:37

2019-11-22 09:30:59

設(shè)計(jì)Java程序員

2020-04-07 08:51:25

CCNP協(xié)議網(wǎng)絡(luò)協(xié)議路由

2022-09-15 07:05:09

Windows電腦技巧

2013-06-03 10:02:53

WAF繞過(guò)

2024-02-19 08:07:31

Go版本語(yǔ)言

2019-07-25 10:45:05

GitHub技巧網(wǎng)站

2025-03-25 10:49:13

2024-10-28 13:18:54

2022-09-06 08:07:24

SQL語(yǔ)句查詢

2011-07-05 14:59:17

java
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)