《Cracking the Coding Interview》——第11章:排序和搜索——題目8

2014-03-21 22:23

題目:假設你一開始有一個空數組,你在讀入一些整數并將其插入到數組中,保證插入之后數組一直按升序排列。在讀入的過程中,你還可以進行一種操作:查詢某個值val是否存在于數組中,并給出這個元素在數組中的位置(如果有多個的重復元素話,給出最小的下標)。

解法:書上的原題不是這么描述的,但我覺得用這種插入排序的說法更好理解。雖然說是數組,但實際上既可以用真的數組來模擬這一過程,也可以用一棵二叉搜索樹來做。我的實現是用二叉搜索樹,每個節點里除了記錄元素的值之外,還記錄它的左子樹有多少個點。這樣在樹里面也能進行對數級的查找。其實,用數組直接模擬的話,代碼應該更好寫的。

代碼:

 1 // 11.8 Given an array of integers, find out for a given value, how many integers are there in the array, that are no greater than the value.
 2 // If the value is not in the array, return -1 instead.
 3 #include <algorithm>
 4 #include <iostream>
 5 #include <string>
 6 using namespace std;
 7 
 8 struct TreeNode {
 9     int val;
10     int count;
11     int count_left;
12     TreeNode *left;
13     TreeNode *right;
14     TreeNode(int _val = 0): val(_val), count(1), count_left(0), left(nullptr), right(nullptr) {};
15 };
16 
17 void insertNode(TreeNode *&root, int val)
18 {
19     if (root == nullptr) {
20         root = new TreeNode(val);
21     } else if (val == root->val) {
22         ++(root->count);
23     } else if (val < root->val) {
24         ++(root->count_left);
25         insertNode(root->left, val);
26     } else {
27         insertNode(root->right, val);
28     }
29 }
30 
31 int getRank(TreeNode *root, int val)
32 {
33     int result;
34     TreeNode *ptr;
35     
36     result = 0;
37     ptr = root;
38     while (ptr != nullptr) {
39         if (ptr->val > val) {
40             ptr = ptr->left;
41         } else if (ptr->val < val) {
42             result += ptr->count_left + 1;
43             ptr = ptr->right;
44         } else {
45             break;
46         }
47     }
48     if (ptr != nullptr) {
49         result += ptr->count_left;
50         return result;
51     } else {
52         return -1;
53     }
54 }
55 
56 void clearTree(TreeNode *&root)
57 {
58     if (root != nullptr) {
59         clearTree(root->left);
60         clearTree(root->right);
61         delete root;
62         root = nullptr;
63     }
64 }
65 
66 int main()
67 {
68     int val;
69     TreeNode *root;
70     string s;
71     
72     root = nullptr;
73     while (cin >> s) {
74         if (s == "i") {
75             cin >> val;
76             insertNode(root, val);
77         } else if (s == "r") {
78             cin >> val;
79             printf("rank = %d\n", getRank(root, val));
80         } else if (s == "e") {
81             break;
82         }
83     }
84     clearTree(root);
85     
86     return 0;
87 }

?

轉載于:https://www.cnblogs.com/zhuli19901106/p/3616871.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/376050.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/376050.shtml
英文地址,請注明出處:http://en.pswp.cn/news/376050.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

gradle打包java項目_gradle打包java項目

轉載地址&#xff1a;http://www.gfzj.us/series/gradle/2014/12/12/gradle%E5%B0%8F%E7%B3%BB%E5%88%97(4)--gradle%E6%89%93%E5%8C%85java%E9%A1%B9%E7%9B%AE.html以gradle小系列所舉例子為示例&#xff0c;在此處介紹兩種gradle發布java項目的方法&#xff1a;fat jar方式該…

堡壘機2.0

一、編輯系統環境變量&#xff0c;讓用戶登錄后自動調用腳本 1 vim /etc/profile 2 python /baolei/ssh_login.py 3 # 判斷登錄用戶是否為 root 用戶&#xff0c;root用戶退出程序不進行logout操作&#xff0c;否則則logout 4 if [ $? ! 10 ];then 5 echo "Good …

Flex中利用ByteArray與BitmapData互相轉換實現圖片的二進制保存與復原

Flex中利用ByteArray與BitmapData互相轉換實現圖片的二進制保存與復原 近 日在項目當中需要將圖片保存到共享對象當中&#xff0c;開始用了倆天的時間做了對象的序列化&#xff0c;并以BitmapData的形式進行了圖片的序列化保存共享&#xff0c;因為系統 沒有提供更好的接口所以…

java8自定義收集器_使用自定義收集器進行Java 8分組?

我有以下課程。class Person {String name;LocalDate birthday;Sex gender;String emailAddress;public int getAge() {return birthday.until(IsoChronology.INSTANCE.dateNow()).getYears();}public String getName() {return name;}}我希望能夠按年齡分組&#xff0c;然后收…

poj 1862 Stripies/優先隊列

原題鏈接&#xff1a;http://poj.org/problem?id1862 簡單題&#xff0c;貪心優先隊列主要練習一下stl大根堆 寫了幾種實現方式寫成類的形式還是要慢一些。。。 手打的heap&#xff1a; 1&#xff1a; 1 #include<cstdio>2 #include<cstdlib>3 #include<cmath&…

java url下載ics_使用Microsoft Graph API處理外部(Internet / .ics)日歷URL

在新的Graph API中&#xff0c;是否可以根據外部.ics日歷網址為用戶創建新日歷&#xff1f;我d like to do is to use a daemon to inject a link to an external calendar into the list of calendars a user has if they don已經有了這樣一個鏈接 . 這將有效地復制用戶可以在…

命令行生成jar文件

1.打開cmd&#xff0c;進入編譯完后所有類的當前目錄 命令行 jar -cvf javaname.jar *.class 這時已經生成了 javaname.jar 不過如果有多個類&#xff0c;雙擊打不開 2.解壓javaname.jar 進入META-INF&#xff0c;編輯MANIFEST.MF: 尾行寫入Main-Class:&#xff08;&…

Github鏈接地址

https://github.com/kzj1/test轉載于:https://www.cnblogs.com/lalal/p/4456923.html

java foreach和for循環區別_java相關:老生常談foreach(增強for循環)和for的區別

java相關&#xff1a;老生常談foreach(增強for循環)和for的區別發布于 2020-8-18|復制鏈接下面小妖就為大家帶來一篇老生常談foreach(增強for循環)和for的區別。小妖覺得挺不錯的&#xff0c;現在就分享給大家&#xff0c;也給大家做個參考。一起跟隨小妖過來看看吧首先說一下f…

關于事件冒泡和捕獲的問題

由于習慣于jquery的方便操作&#xff0c;往往讓我們慢慢淡忘了原生js應有的功能和屬性&#xff0c;今天重溫一下事件冒泡和捕獲問題。 冒泡&#xff1a;從內向外&#xff0c;如&#xff1a;div > body > html (不同瀏覽器稍有不同) 捕獲&#xff1a;從外向內&#xff0c;…

root無法運行命令解決辦法

今天運行一個命令wget(wg再使用tab鍵無法使用)&#xff0c;如下提示 -bash: /usr/bin/wget: 權限不夠 [rootwww /]# ls -Z /usr/bin/wget-rw-r--r--. root root system_u:object_r:bin_t:s0 /usr/bin/wget發現沒有執行權限 chmod x /usr/bin/wget -bash: /usr/bin/wget: …

java類編寫sql_用JavaBean編寫SQL Server數據庫連接類

以下為引用的內容&#xff1a;//類conn.db.conndb.javapackage conn.db;import java.sql.*;public class conndb {Connection conn;ResultSet rs;private int count;public conndb() {try {Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");} catch (Exception ex) {}…

ASP.NET中Request.ApplicationPath、Request.FilePath、Request.Path、.Request.MapPath、

1.Request.ApplicationPath->當前應用的目錄 Jsp中, ApplicationPath指的是當前的application(應用程序)的目錄,ASP.NET中也是這個意思。 對應的--例如我的服務器上有兩個web應用域名都是mockte.com 一個映射到目錄mockte.com/1/ 另一個影射到 http://mockte.com/2/ …

java timezone id_java.util.TimeZone.setID()方法實例

全屏setID(String ID)方法被用于設置時區ID。這不會改變的時區對象中的任何其他數據。聲明以下是java.util.TimeZone.setID()方法的聲明。public void setID(String ID)參數ID--這是新的時區ID。返回值NA異常NA例子下面的例子顯示java.util.TimeZone.setID()方法的使用package …

c語言中賦值截斷

在c語言中進行變量賦值的時候&#xff0c;如果將字節多的數據類型賦給一個占字節少的變量類型&#xff0c;會發生“截斷”。 發生這種情況的原因是&#xff1a;在賦值過程中只將占字節較長的變量的地位賦給占字節較少的變量。 如&#xff1a; int i345&#xff1b; char c‘…

創建一個自己的GitHub,創建自己的開源項目

作者是一個大學在讀學生&#xff0c;自己在平時的學習中&#xff0c;GitHub上的開源項目給自己提供了很大的幫助。GitHub是目前使用最廣泛的分布式項目管理軟件&#xff0c;GitHub上面托管了許多非常優秀的開源項目。我覺得每一個從事IT行業都應該有一個屬于自己的GitHub。下面…

設計模式之行為型(1)-職責鏈模式(Chain)

設計模式之行為型(1)-職責鏈模式(Chain)轉載于:https://www.cnblogs.com/lihuali/p/7493415.html

php apache win7,win7安裝apache+php

轉自百度經驗1 系統環境與軟件1php5.5.6 下載鏈接&#xff1a;http://windows.php.net/download/#php-5.5推薦 V11 x64&#xff0c;也就是64bit的。2apache2.4&#xff0c;下載鏈接&#xff1a;http://www.apachelounge.com/download/同樣是推薦 V11&#xff0c;64位的。3前面提…

photoshop 常用快捷鍵大全

一、文件新建 CTRLN打開 CTRLO 打開為 ALTCTRLO關閉 CTRLW保存 CTRLS 另存為 CTRLSHIFTS另存為網頁格式 CTRLALTS打印設置 CTRLALTP頁面設置 CTRLSHIFTP打印 CTRLP退出 CTRLQ 二、編輯撤消 CTRLZ向前一步 CTRLSHIFTZ向后一步 CTRLALTZ退取 CTRLSHIFTF剪切 CTRLX復制 CTRLC合并…

Ubuntu如何安裝setuptools

首先百度setuptools&#xff0c;基本第一個就是官網的結果然后我們看到有兩個這樣的文件第一個不用想了&#xff0c;如果你要使用第一個的話&#xff0c;還要首先安裝wheel。我們這里直接用鼠標選中第二個zip文件&#xff0c;然后右鍵&#xff0c;復制鏈接。然后在我們的Ubuntu…