一年十二月  誰主春秋
關(guān)注:基礎(chǔ)系統(tǒng)工程 密碼學(xué) 人工智能
C++博客
首頁
新隨筆
聯(lián)系
聚合
管理
隨筆-161 評論-223 文章-30 trackbacks-0
求單向鏈表倒序第m個元素
原題為某游戲公司試題,大意如下:
對于一個單向鏈表,試寫出找到它的倒序第m
個元素(m >= 1)的函數(shù),注意變量命名、注釋、時間復(fù)雜度、空間復(fù)雜度。
注:要求寫出可編譯并可以運行通過的程序代碼。
這道題的常規(guī)做法或者說首先想到直覺的方法M1是先求得鏈表的長度,即元素總個數(shù)n,然后問題轉(zhuǎn)化為求順序第n-m+1個元素。下面給出第2種方法M2:先求得順序第m個元素,用一指針P指向這個元素,用另一指針PR指向鏈表的頭部,現(xiàn)在好了,P和PR同時向右移動,直到P為空,則PR就是要求的倒序第m個元素,如果因m超越界限,則PR為空,表示沒找到,這樣一來,只需一次循環(huán)就夠了。C++代碼描述如下
1
template
<
typename T
>
2
struct
Node
3
{
4
T data;
/**/
/**/
/**/
///
< 數(shù)據(jù)
5
Node* next;
///
< 指向下一結(jié)點的指針
6
} ;
7
8
template
<
typename T
>
9
Node
<
T
>*
ReverseFind(Node
<
T
>*
head, size_t m)
10
{
11
size_t n
=
0
;
12
Node
<
T
>
*
p,
*
pR
=
NULL;
13
for
(p
=
head;p;p
=
p
->
next)
14
{
15
if
(
++
n
==
m)
16
{
17
pR
=
head;
18
continue
;
19
}
20
if
(pR)
21
{
22
pR
=
pR
->
next;
23
}
24
}
25
return
pR;
26
}
現(xiàn)在分析這2種方法的時間復(fù)雜度,假設(shè)鏈表元素個數(shù)為N,所求倒序為第M元素,N>=M,則M1方法為0(N)+0(N-M)=0(2N-M),M2方法為O(M)+O(N-M)=0(N),因此M2快于M1。
posted on 2011-06-24 11:40
春秋十二月
閱讀(2555)
評論(11)
編輯
收藏
引用
所屬分類:
Algorithm
評論:
#
re: 求單向鏈表倒序第m個元素 2011-06-24 12:30 |
coreBugZJ
贊一個
回復(fù)
更多評論
#
re: 求單向鏈表倒序第m個元素 2011-06-24 16:45 |
paw
額,,考研數(shù)據(jù)結(jié)構(gòu)題。。。
回復(fù)
更多評論
#
re: 求單向鏈表倒序第m個元素 2011-06-24 23:57 |
魚吃貓
頂一個~
回復(fù)
更多評論
#
re: 求單向鏈表倒序第m個元素[未登錄] 2011-06-25 12:06 |
英雄哪里出來
不錯,贊一個~~
回復(fù)
更多評論
#
re: 求單向鏈表倒序第m個元素[未登錄] 2011-06-25 13:39 |
kaka
第一個指針從頭移動到m,和第二個指針一起再移動到尾部。
第二個指針和第一個指針一起移動。
只不過將一個指針大于一次遍歷的操作分解成兩個指針操作。
這樣算是一次遍歷?
回復(fù)
更多評論
#
re: 求單向鏈表倒序第m個元素 2011-06-25 23:36 |
夢提
是一次遍歷,因為時間上是同步的。@kaka
回復(fù)
更多評論
#
re: 求單向鏈表倒序第m個元素 2011-06-26 08:47 |
搞笑
這個也太搞笑了?效率是一樣的,還竟然有:“這樣效率不高”的說法。
回復(fù)
更多評論
#
re: 求單向鏈表倒序第m個元素 2011-06-26 13:54 |
temp
是一樣的,兩個指針分別遍歷。
回復(fù)
更多評論
#
re: 求單向鏈表倒序第m個元素 2011-06-26 15:24 |
Arcko
貌似需要遍歷的確實是一樣的多,不過換個思路考慮也很好
回復(fù)
更多評論
#
re: 求單向鏈表倒序第m個元素 2011-06-27 10:09 |
megadeath
使用遞歸方式(示例代碼,無任何錯誤檢查),把for語句也消隱掉。
static int nOrder = 0;
template <typename ITERATOR, typename UINT>
void F(ITERATOR begin, ITERATOR end, UINT M)
{
ITERATOR it = begin;
if (begin != end)
F(++begin, end, M);
if (++nOrder == ++M)
cout << *it << endl;
}
回復(fù)
更多評論
#
re: 求單向鏈表倒序第m個元素
2011-07-01 11:06 |
有霧
我也感覺效率一樣的。第二個里面,同樣要把P移動到鏈表尾,這樣才能獲得size。所以不存在O(M),同樣是O(N)啊。@搞笑
回復(fù)
更多評論
刷新評論列表
只有注冊用戶
登錄
后才能發(fā)表評論。
【推薦】100%開源!大型工業(yè)跨平臺軟件C++源碼提供,建模,組態(tài)!
相關(guān)文章:
一個歐拉數(shù)整除問題的兩種證法
有限域上的特征與指數(shù)和之?dāng)U展
二元二次型的相似變換、正定性與正交分解
關(guān)于群的一些結(jié)論及應(yīng)用
不定方程的代數(shù)數(shù)論解法
關(guān)于橢圓曲線的驗證計算
不可約多項式判別算法的改正
論證有限域上平方根的求解
求解離散對數(shù)問題的Terr算法
簡單私鑰加密構(gòu)造的驗證及安全性分析
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
本博客所有隨筆均為原創(chuàng),因為不定期維護(hù)更新,所以轉(zhuǎn)載請注明出處,如有問題和建議,請留言或評論,發(fā)表您的寶貴意見,藉此平臺以分享交流、共同進(jìn)步。
聯(lián)系方式:微信math-engineer
<
2014年12月
>
日
一
二
三
四
五
六
30
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
1
2
3
4
5
6
7
8
9
10
常用鏈接
我的隨筆
我的評論
我參與的隨筆
留言簿
(76)
給我留言
查看公開留言
查看私人留言
隨筆分類
(160)
Algorithm(48)
C/C++(24)
Compiler(25)
Compute Theory(5)
Database(4)
Network(17)
Opensrc(13)
System(24)
隨筆檔案
(161)
2025年6月 (2)
2025年4月 (2)
2024年12月 (1)
2024年11月 (1)
2024年9月 (1)
2024年8月 (2)
2024年6月 (1)
2024年5月 (1)
2024年4月 (1)
2024年3月 (2)
2024年2月 (2)
2023年12月 (1)
2023年11月 (2)
2023年10月 (2)
2023年9月 (37)
2021年12月 (1)
2021年10月 (1)
2021年9月 (1)
2021年2月 (1)
2020年5月 (3)
2020年4月 (1)
2019年11月 (4)
2019年7月 (1)
2018年11月 (1)
2017年12月 (1)
2016年12月 (1)
2016年11月 (2)
2016年10月 (1)
2016年9月 (1)
2016年8月 (3)
2016年7月 (4)
2016年5月 (1)
2015年10月 (2)
2015年9月 (1)
2015年6月 (2)
2015年5月 (3)
2015年2月 (1)
2015年1月 (1)
2014年12月 (2)
2014年4月 (2)
2014年3月 (1)
2014年1月 (1)
2013年10月 (1)
2013年9月 (1)
2013年8月 (3)
2013年5月 (1)
2013年3月 (1)
2012年11月 (1)
2012年9月 (3)
2012年8月 (1)
2012年7月 (1)
2012年6月 (5)
2012年5月 (3)
2011年12月 (5)
2011年11月 (1)
2011年10月 (5)
2011年8月 (7)
2011年7月 (6)
2011年6月 (6)
2010年6月 (1)
2009年12月 (1)
2009年8月 (1)
2009年7月 (1)
2009年6月 (1)
2009年4月 (3)
文章分類
(30)
詩詞作品集(30)
關(guān)注的開源項目
LLVM
編譯系統(tǒng)
nginx
高性能Web服務(wù)器
OpenSSL
密碼學(xué)庫
suricata
網(wǎng)絡(luò)IPS引擎
最新隨筆
1.?一個歐拉數(shù)整除問題的兩種證法
2.?有限域上的特征與指數(shù)和之?dāng)U展
3.?二元二次型的相似變換、正定性與正交分解
4.?關(guān)于群的一些結(jié)論及應(yīng)用
5.?不定方程的代數(shù)數(shù)論解法
6.?關(guān)于橢圓曲線的驗證計算
7.?不可約多項式判別算法的改正
8.?論證有限域上平方根的求解
9.?求解離散對數(shù)問題的Terr算法
10.?簡單私鑰加密構(gòu)造的驗證及安全性分析
積分與排名
積分 - 416973
排名 - 56
最新評論
1.?re: 一種攔截Linux原始套接字IO的方法[未登錄]
很有前途和很有錢途啊。
--chipset
2.?re: 一種攔截Linux原始套接字IO的方法[未登錄]
@chipset
是的
--春秋十二月
3.?re: 一種攔截Linux原始套接字IO的方法[未登錄]
工作是做網(wǎng)絡(luò)安全?
--chipset
4.?re: 一種使用函數(shù)指針實現(xiàn)狀態(tài)機(jī)的方法
函數(shù)指針實現(xiàn)狀態(tài)機(jī)
--linda
5.?re: 多標(biāo)簽視圖類CTabView的設(shè)計實現(xiàn)
為啥代碼缺少一些呢,給新手個完整點的啊
--pekingliu
6.?re: 工作線程與消息循環(huán)
從消息隊列取出消息 mark了
--mmocake
7.?re: 一種簡單的跨平臺套接字管道
評論內(nèi)容較長,點擊標(biāo)題查看
--IT搬運工
8.?re: 一種簡單的跨平臺套接字管道
windows僅支持af_init和af_init6地址族有錯別字么?
af_init和af_init6
--IT搬運工
9.?re: Shell應(yīng)用(8):使用awk定位反匯編輸出[未登錄]
厲害
--Chipset
10.?re: TCP分組丟失時的狀態(tài)變遷
不錯
--Binky
閱讀排行榜
1.?基于OpenSSL實現(xiàn)的安全連接(14001)
2.?字符串16進(jìn)制顯示(12881)
3.?基于boost asio實現(xiàn)的ssl socket框架(12342)
4.?Linux套接字與虛擬文件系統(tǒng)(1):初始化和創(chuàng)建(8668)
5.?關(guān)于數(shù)據(jù)庫的一些學(xué)習(xí)研究心得(8109)
6.?使用CString GetBuffer自適應(yīng)獲取計算機(jī)名稱(7985)
7.?使用正則表達(dá)式解析URL(7949)
8.?basic_string內(nèi)存泄露問題之分析解決(7753)
9.?Shell應(yīng)用(4): 使用sed刪除行尾的^M字符(7671)
10.?nginx iocp(1):tcp異步連接(7657)
評論排行榜
1.?basic_string內(nèi)存泄露問題之分析解決(19)
2.?求單向鏈表倒序第m個元素(11)
3.?基于順序存儲實現(xiàn)的多叉樹(1):深度優(yōu)先存儲(9)
4.?字符大小寫轉(zhuǎn)換(7)
5.?字符串16進(jìn)制顯示(6)
6.?面向?qū)ο箧i框架的設(shè)計與實現(xiàn)(6)
7.?Shell應(yīng)用(4): 使用sed刪除行尾的^M字符(5)
8.?使用正則表達(dá)式解析URL(5)
9.?工作線程與消息循環(huán)(5)
10.?十進(jìn)制整數(shù)千位分隔符(4)
Powered by:
博客園
模板提供:
滬江博客
Copyright ©2025 春秋十二月
亚洲午夜久久久久久噜噜噜
|
亚洲精品乱码久久久久久蜜桃
|
亚洲精品无码久久久久去q
|
国内精品久久久久久久coent
|
亚洲精品无码久久久久
|
国产情侣久久久久aⅴ免费
|
人妻久久久一区二区三区
|
久久久精品国产sm调教网站
|
麻豆精品久久久久久久99蜜桃
|
久久精品国产亚洲网站
|
久久一区二区三区免费
|
久久久噜噜噜久久中文福利
|
久久国产香蕉一区精品
|
乱亲女H秽乱长久久久
|
午夜精品久久久内射近拍高清
|
亚洲成色WWW久久网站
|
久久有码中文字幕
|
国产精品久久午夜夜伦鲁鲁
|
亚洲国产天堂久久综合
|
欧美777精品久久久久网
|
久久AV高清无码
|
曰曰摸天天摸人人看久久久
|
久久AV无码精品人妻糸列
|
久久电影网
|
四虎影视久久久免费
|
久久久久国产精品三级网
|
99久久精品国产毛片
|
久久久久久av无码免费看大片
|
中文字幕亚洲综合久久
|
九九热久久免费视频
|
精品久久久久成人码免费动漫
|
久久e热在这里只有国产中文精品99
|
怡红院日本一道日本久久
|
av无码久久久久久不卡网站
|
久久丫精品国产亚洲av不卡
|
99久久国产综合精品网成人影院
|
久久99久久无码毛片一区二区
|
合区精品久久久中文字幕一区
|
久久精品国产亚洲αv忘忧草
|
久久久久国产精品熟女影院
|
亚洲精品无码久久久久AV麻豆
|