日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

数组基操三连(4)

發(fā)布時(shí)間:2023/12/13 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 数组基操三连(4) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

題目一

給定一個(gè)長(zhǎng)度為N的整型數(shù)組arr,其中有N個(gè)互不相等的自然數(shù)1~N

請(qǐng)實(shí)現(xiàn)arr的排序

但是不要把下標(biāo)0~N-1位置上的數(shù)值通過直接賦值的方式替換成1~N。

要求:時(shí)間復(fù)雜度為O(N),額外空間復(fù)雜度為O(1)。

?

思路:從左向右檢查,檢查到需要換的以后,就直接把它放到該去的位置,然后被換掉的數(shù),位置肯定也不對(duì),繼續(xù)重復(fù)相同的方法,最后肯定會(huì)跳回來(原因懶得說了自己想想),然后繼續(xù)往下檢查即可。

public static void sort1(int[] arr) {int tmp = 0;int next = 0;for (int i = 0; i != arr.length; i++) {tmp = arr[i];while (arr[i] != i + 1) {next = arr[tmp - 1];arr[tmp - 1] = tmp;tmp = next;}}}

題目二

本題一般思路:依次查找找到比前后都小的數(shù);或者選出最小數(shù),他肯定是局部最小的;等等

但這些都是O(n)的方法,而用二分可以做到O(logn).

二分思路:

??考慮最左和最右的元素:如果arr[0]<arr[1] ?return?0; arr[N-1]<arr[N-2] return?N-1;

???考慮最中間元素,如果中間元素大于它左邊的元素,那么局部最小值就應(yīng)該在數(shù)組的左半部分

???如果中間元素小于大于它右邊的元素,那么局部最小值就應(yīng)該在數(shù)組的右半部分

???中間元素既小于它左邊的值又小于它右邊的值,那么它就是局部最小
?

題目三

?

給定一個(gè)整數(shù)數(shù)組arr,返回不包含本位置的累乘數(shù)組。

比如2 3 1 4返回12 8 24 6

方法一:算出所有數(shù)的乘積,每個(gè)位置除以自己即可。要注意坑:如果數(shù)組中有一個(gè)0,那么0這個(gè)位置就是其他數(shù)的乘積,其他位置全為0;如果有多個(gè)0,那么所有位置都是0.

public int[] product1(int[] arr) {if(arr==null || arr.length<2) {return null;}int count=0;//0的個(gè)數(shù)int all=1;//除0以外的數(shù)的乘積for(int i=0;i!=arr.length;i++) {if(arr[i]!=0) {all*=arr[i];}else {count++;}}int[] res=new int[arr.length];if(count==0) {for(int i=0;i!=arr.length;i++) {res[i]=all/res[i];}}else if(count==1) {for(int i=0;i!=arr.length;i++) {if(arr[i]==0) {res[i]=all;}}}return res;}

?

總結(jié)

以上是生活随笔為你收集整理的数组基操三连(4)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。