亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 4856 | 回復(fù): 8
打印 上一主題 下一主題

[C] 一道看似不起眼的小題 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2014-10-17 13:27 |只看該作者 |倒序?yàn)g覽
本帖最后由 zhendehaoren 于 2014-10-17 18:56 編輯

面試的時(shí)候最怕遇到“小題”

這次栽在了這樣的一道題上面:
a[1000]數(shù)組, 用隨機(jī)函數(shù)隨機(jī)生成1000填充,不允許重復(fù),也就是說不止1000次,復(fù)雜度最低實(shí)現(xiàn)

以下三個(gè)方法已經(jīng)確認(rèn)不是最優(yōu)解(也就是說和沒答一樣,“小題”就是如此殘酷)
1 另外存放一個(gè)二叉排序樹,每次插入時(shí)遍歷二叉樹。

2 另外存放一個(gè)排序數(shù)組,每次插入時(shí)二分查找。

3 另外存放一個(gè)數(shù)組或bitmap,每次產(chǎn)生一個(gè)數(shù)字對應(yīng)的下標(biāo)置1,快速查看是否已存在。

經(jīng)過查資料,貌似需要洗牌算法。
我的理解,洗牌算法就是將一堆數(shù)字打亂,這樣的話,和這道題有什么聯(lián)系?

論壇徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16賽季CBA聯(lián)賽之青島
日期:2016-07-05 12:36:0515-16賽季CBA聯(lián)賽之廣東
日期:2016-06-29 11:45:542015亞冠之全北現(xiàn)代
日期:2015-07-22 08:09:472015年辭舊歲徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39獅子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技術(shù)圖書徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
2 [報(bào)告]
發(fā)表于 2014-10-17 14:15 |只看該作者
你將要求說清楚點(diǎn)

若“a[1000]數(shù)組, 用隨機(jī)函數(shù)隨機(jī)生成1000次填充”,就直接for循環(huán)啦
若再加上“不允許重復(fù)”,用 set 或 unordered_set 之類
若再加上“填充0到999,不允許重復(fù)”,看 std::random_shuffle

論壇徽章:
0
3 [報(bào)告]
發(fā)表于 2014-10-17 14:29 |只看該作者
本帖最后由 317358117 于 2014-10-17 14:37 編輯

如果是0~999打亂的話可以這樣

  1. for(i = 0; i < 1000; i++) { a[i] = i; }

  2. for(i = 0; i < 999; i++) {
  3.     k = rand() % (1000-i);
  4.     swap(a[i], a[i+k]);
  5. }
復(fù)制代碼
如果是值是隨機(jī)的,可以隨機(jī)一個(gè)數(shù)a作為起始,每次隨機(jī)增量與起始相加得到b,然后再a=b,可以得到升序的隨機(jī)序列

論壇徽章:
0
4 [報(bào)告]
發(fā)表于 2014-10-17 14:42 |只看該作者
多謝ls,完全看不懂,不過即使這樣,復(fù)雜度也得是o(2n)

如果采用第三種方法,o(n)就行了

論壇徽章:
2
2015年辭舊歲徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:11
5 [報(bào)告]
發(fā)表于 2014-10-17 14:47 來自手機(jī) |只看該作者
又沒說數(shù)的范圍。若范圍是32位整數(shù),則可以將這個(gè)區(qū)間1000等分,每個(gè)區(qū)間取個(gè)隨機(jī)數(shù)填充即可,復(fù)雜度o(n)

論壇徽章:
3
2015年辭舊歲徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:032015年亞洲杯之中國
日期:2015-04-22 15:52:45
6 [報(bào)告]
發(fā)表于 2014-10-17 16:34 |只看該作者
zhendehaoren 發(fā)表于 2014-10-17 14:42
多謝ls,完全看不懂,不過即使這樣,復(fù)雜度也得是o(2n)

如果采用第三種方法,o(n)就行了


這樓可是標(biāo)準(zhǔn)的洗牌算法哦, 先得初始化一遍, 總得先有1000張牌么不是.

另外, 題目說是"隨機(jī)生成1000次填充", 如果出現(xiàn)重復(fù)就不滿足"1000次"這個(gè)硬性需求了.
沒有指明數(shù)值范圍, 那靈活性太大了, 自己想辦法不讓它重復(fù)罷了.

感覺題目出得不好.

論壇徽章:
1
巨蟹座
日期:2014-03-18 23:44:30
7 [報(bào)告]
發(fā)表于 2014-10-19 00:22 |只看該作者
5樓 區(qū)間等分  給個(gè)贊

論壇徽章:
11
2015年迎新春徽章
日期:2015-03-04 09:55:282017金雞報(bào)曉
日期:2017-02-08 10:39:4215-16賽季CBA聯(lián)賽之遼寧
日期:2016-12-15 10:24:1715-16賽季CBA聯(lián)賽之佛山
日期:2016-11-30 09:04:2015-16賽季CBA聯(lián)賽之江蘇
日期:2016-04-29 15:56:1215-16賽季CBA聯(lián)賽之同曦
日期:2016-04-12 13:21:182016猴年福章徽章
日期:2016-02-18 15:30:3415-16賽季CBA聯(lián)賽之山東
日期:2016-02-16 11:37:52每日論壇發(fā)貼之星
日期:2016-02-07 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2016-02-07 06:20:0015-16賽季CBA聯(lián)賽之新疆
日期:2018-01-09 16:25:37
8 [報(bào)告]
發(fā)表于 2014-10-22 14:57 |只看該作者
本帖最后由 bskay 于 2014-10-22 15:03 編輯

等分還不如這樣呢:
for (i = 0; i < 1000; i++)
{
     a = i*1000+(rand()%1000);
}


上面看起來不太像隨機(jī)數(shù),哪能相隔那么多啊,其實(shí)只要考慮到i作為一個(gè)因素就可以了,但是不能讓它過大的影響數(shù)的分布
要降低它的"貢獻(xiàn)值",可以參考取hash值的函數(shù)那樣移位啊與啊和啊的..就能保證唯一,也不需要查有序表

論壇徽章:
13
CU大;照
日期:2013-04-17 11:20:3615-16賽季CBA聯(lián)賽之吉林
日期:2017-05-25 16:45:4715-16賽季CBA聯(lián)賽之福建
日期:2017-03-13 11:33:442017金雞報(bào)曉
日期:2017-02-08 10:39:422017金雞報(bào)曉
日期:2017-01-10 15:13:29IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-03-15 06:20:01IT運(yùn)維版塊每日發(fā)帖之星
日期:2015-10-02 06:20:00CU十二周年紀(jì)念徽章
日期:2013-10-24 15:41:34CU大;照
日期:2013-09-18 15:15:45CU大牛徽章
日期:2013-09-18 15:15:15CU大牛徽章
日期:2013-04-17 11:46:39CU大;照
日期:2013-04-17 11:46:28
9 [報(bào)告]
發(fā)表于 2014-10-22 21:42 |只看該作者
本帖最后由 xdsnet 于 2014-10-22 21:46 編輯

如果要真正的隨機(jī)數(shù),則不能洗牌算法吧
應(yīng)該是類似樓主3的算法,不過這個(gè)算法存在不能結(jié)束收斂的可能,所以不是復(fù)雜度最低的算法,這時(shí)如果單純考慮降低復(fù)雜度,其實(shí)可以考慮一個(gè)移位+后續(xù)位算法,絕對不存在重復(fù)(純理論,在支持大數(shù)乘法——長整數(shù)的條件下),可以實(shí)現(xiàn)O(1),rand()表示取一個(gè)隨機(jī)整數(shù)。
步進(jìn)一個(gè)計(jì)數(shù)器n
填充到數(shù)組中的過程
for (n=0;n<1000;n++){
a[n]=rand()*1000+n;
}
因?yàn)楹?個(gè)十進(jìn)制位肯定不同,所以這個(gè)算法填充的隨機(jī)數(shù)不會(huì)重復(fù)的。

其實(shí)和樓上的差不多效果(我開始是沒有看見樓上的),但性質(zhì)不同,樓上的隨機(jī)數(shù)范圍要小很多的,這個(gè)理論取值范圍是[0,max(rand())*1000+999],樓上的取值范圍是[0,999999],而且填充是肯定的升序,我的排序是不固定的。可以通過rand()的設(shè)計(jì)控制范圍(比如用不到長整數(shù))。
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP