درخت فنویک

یک درخت فنویک که اعداد ۱ تا ۵ به ترتیب در آن درج می شوند.

فرض کنید آرایه a به اندازه n که در ابتدا همه مقادیر آن برابر ۰ هستند به ما داده شده‌است، می‌خواهیم اعمال زیر را روی این آرایه انجام دهیم:

  • به درایه i-ام، x واحد اضافه کن.
  • مجموع اعداد درایه i-ام تا درایه j-ام را به دست بیاور.

یک راه حل ساده برای این مسئله با استفاده از آرایه، به این صورت است که دستور ۱ را در (۱)O و دستور ۲ را در انجام می‌دهد. پس اگر m دستور داشته باشیم، در بدترین حالت (زمانی که همه دستورها از نوع دوم باشند)، به زمان احتیاج داریم. با استفاده از داده ساختار درخت فنویک (یا درخت اندیس داده شده دودویی) می‌توان هر دستور را در و در نتیجه کل دستورها را در انجام داد. به‌طور کلی این اعمال توسط درخت بازه‌ها هم در این زمان انجام می‌شوند، اما مزیت درخت فنویک در کم بودن حافظه (دقیقاً به اندازه n)، کوتاه بودن کد و همچنین سهولت پیاده‌سازی آن در ابعاد بیشتر است.

تعریف می‌کنیم:

  • مجموع درایه‌های اول تا i-ام (فراوانی تراکمی درایه i-ام):
  • مجموع درایه‌های i-ام تا j-ام:

یک راه کند دیگر

این راه حل زمانی که همه دستورهای نوع دوم بعد از دستورها نوع اول باشند، m دستور را در انجام می‌دهد.

به وضوح:

بعد از این که همه دستورها نوع اول، مانند راه قبل در انجام شدند، به صورت پویا مقادیر آرایه c را در محاسبه می‌کنیم. بنابر تعریف :c

void initialize(){
c[0] = 0;
for(int i=1; i<=n; i++)
c[i] = c[i-1] + a[i];
}

بعد از این مقدار دهی هم مانند بالا می‌توانیم مقادیر sum را از روی c به دست بیاوریم. پس کل دستورها را در انجام می‌دهیم. اما اگر دستورها نوع دوم بعد از نوع اول نباشند، بعد از هر دستور نوع اول باید مقادیر آرایه c را به روز کنیم، پس باز هم‌زمان اجرا در بدترین حالت از می‌شود.

درخت فنویک

ساختار

ایده اصلی این درخت این است که هر عدد طبیعی را می‌توان به صورت جمع تعدادی از توان‌های ۲ نوشت. به همین ترتیب مجموع یک بازه را می‌توان به صورت جمع تعدادی زیربازه بدون اشتراک از آن بازه نوشت.

فرض کنید r کوچکترین عددی باشد که بیت r-ام عدد x برابر ۱ باشد. تعریف می‌کنیم:

( = عدد i ام آرایه ورودی و = جمع اولین عدد تا iامین عدد ارائه و = جمع اعدادی که در بازهٔ نسبت داده شده به عدد i در ارائه قرار دارند)

مثال:

پیدا کردن آخرین بیت ۱

فرض کنید می‌خواهیم کوچکترین بیت عدد P که برابر ۱ است را به دست آوریم، P را می‌توان به صورت x1y نوشت که x برابر بیت‌های قبل از آخرین ۱ و y برابر تعدادی ۰ است. می‌خواهیم عدد P- را محاسبه کنیم:

((q)¯ مکمل دوی q می‌باشد)

P = (x1y)¯ + ۱ = x¯0y¯ + ۱ = x¯0(0...0)¯ + ۱ = x¯0(1...1) + ۱ = x¯1(0...0) = x¯1y- حال اگر از عملگر «و» بیتی بین P , P- استفاده کنیم، خواهیم داشت:

(P & (-P) = (x1y) & (x¯1y) = (x&x¯)1(y&y) = (۰…۰)۱(۰…۰

بدست آوردن آرایه c از روی آرایه tree

برای بدست آوردن [c[x ابتدا متغیر sum را برابر [tree[x قرار می‌دهیم، سپس بیت آخر x را حذف می‌کنیم و sum را با[tree[x جمع می‌کنیم، همین کار را تکرار می‌کنیم تا x برابر ۰ شود.

مثال: [c[15] = sum[15] + sum[14]+ sum[12] + sum[8

int c(int x){
 int sum = 0;
 for(; x> 0; x -= x & (-x))
  sum += tree[x];
return sum;
}

به‌طور کلی می‌توانیم بگوییم که در درخت، راس x پدر تمام رئوسی است که با حذف بیت آخرشان به x تبدیل می‌شوند:

بنابر این می‌توان (c(x را در زمان محاسبه کرد، در نتیجه می‌توان [sum[i...j و همچنین [a[i را نیز در بدست آورد.([a[i] = sum[i...i)

به روز کردن مقادیر tree

بعد از این که به درایه i-ام، مقدار val را اضافه می‌کنیم، باید به همه [tree[jهایی که i در بازه j قرار می‌گیرد، مقدار val را اضافه کنیم. برای این کار ابتدا به [tree[i، این مقدار را اضافه می‌کنیم، سپس کوچکترین بیت ۱ در i را به آن اضافه می‌کنیم و تا زمانی که i<=n باشد این کار را ادامه می‌دهیم.

void update(int i, int val){
 for(; i<=n; i += i & (-i))
  tree[i] += val;
}

به این ترتیب می‌توانیم به هر دو دستور در جواب دهیم.

پیاده‌سازی در دو بعد

به وسیله توابع زیر می‌توان درخت فنویک را در دو بعد پیاده‌سازی کرد.

int c(int x, int y){
int sum = 0;
for(; x> 0; x -= x & (-x))
for(int i=y; i> 0 ; i -= i & (-i))
sum += tree[x][i];
return sum;
}

void update(int x, int y, int val){
for(; x<=n; x += x & (-x))
for(int i=y; i<=n; i += i & (-i))
tree[x][i] += val;
}

کاربردها

درخت فنویک در مسائلی که به فراوانی تراکمی مربوط می‌شوند مورد استفاده قرار می‌گیرد.

جستارهای وابسته

منابع


Read other articles:

  هذه المقالة عن قصة حب 2050 - فيلم هندي. لمعانٍ أخرى، طالع قصة حب (توضيح). قصة حب 2050ملصق الفيلممعلومات عامةالصنف الفني فيلم خيال علمي — فيلم موسيقي — فيلم دراما — فيلم رومانسي الموضوع سفر عبر الزمن تاريخ الصدور 2008مدة العرض 180 دقيقة[1] اللغة الأصلية هنديةالبلد  الهن...

 

Jānis Mediņš Información personalNacimiento 9 de octubre de 1890 Riga (Imperio ruso) Fallecimiento 4 de marzo de 1966 Estocolmo (Suecia) Nacionalidad Letona y rusaInformación profesionalOcupación Director de orquesta, compositor, violinista y violonchelista Área Música Género Ópera y sinfonía Instrumento Violín Distinciones Orden de la Bandera Roja del TrabajoOrden de las Tres Estrellas [editar datos en Wikidata] Jānis Mediņš (9 de octubre de 1890 — 4 de marzo de 19...

 

JCB Co., Ltd.IndustriJasa keuanganDidirikan1961KantorpusatMinato, Tokyo, JepangWilayah operasiSeluruh duniaTokohkunciTakao Kawanishi (川西 孝雄)(Direktur eksekutif)ProdukSistem pembayaranKartu kreditTotal aset ¥ 10.61610 miliarKaryawan2,706 (2012)Situs webwww.global.jcb JCB Co., Ltd. (株式会社ジェーシービーcode: ja is deprecated , Kabushiki gaisha jē shī bī) (Sebuah inisial dari nama perusahaan sebelumnya, Japan Credit Bureau) adalah sebuah perusahaan kartu kredit yang be...

Ambrósio Fernandes Brandão Nascimento 1555 Morte 1618 (aprox.) Nacionalidade  Portugal Ambrósio Fernandes Brandão (Portugal, 1555 — 1618) foi um senhor de engenho e escritor português, que viveu no Brasil Colonial entre os séculos 16 e 17 e deixou a célebre obra Diálogos das grandezas do Brasil, na qual narra sua estada em terras brasileiras.[1] Cristão-novo perseguido pela Inquisição, Brandão estabeleceu-se na Paraíba, onde escreveu esses diálogos e onde também foi senh...

 

Yevgueni Koroliov Yevgueni KoroliovDinero ganado 1 510 466 dólares estadounidensesRécord de su carrera 74–98Récord de su carrera 10–29[editar datos en Wikidata] Yevgueni Yevguénievich Koroliov (Евге́ний Евге́ньевич Королёв, pron.: yievguiéñi karalióf), transcrito al inglés como Evgeny Korolev, (n. 14 de febrero, 1988 en Moscú, Rusia) es un jugador de tenis kazajo. Se destaca por sus poderosos golpes y en su carrera ha conquistado cinc...

 

Fortaleza de Nossa Senhora dos PrazeresParanaguá, Paraná in BrazilFront view of the fortFortaleza de Nossa Senhora dos PrazeresLocation of Fortaleza de Nossa Senhora dos Prazeres in BrazilCoordinates25°30′41″S 48°18′45″W / 25.511389°S 48.3125°W / -25.511389; -48.3125TypeFortSite informationOpen tothe publicYesConditionGood Fortaleza de Nossa Senhora dos Prazeres is a fort located in Paranaguá, Paraná in Brazil.[1][2] See a...

Musical For other uses, see Nice Work If You Can Get It. Nice Work If You Can Get ItMusicGeorge GershwinLyricsIra GershwinBookJoe DiPietroProductions2012 Broadway2014 US tour2015 Melbourne2018 UK, London Nice Work If You Can Get It is a musical featuring songs by George and Ira Gershwin, with a book written by Joe DiPietro, and based on material by Guy Bolton and P. G. Wodehouse.[1] Nice Work premiered on Broadway in April 2012. Background The musical was initially produced in 2001 at...

 

Chiesa di Santa Maria delle GrazieLa chiesa di Santa Maria delle Grazie.Stato Italia LocalitàMarino Coordinate41°46′13.17″N 12°39′14.56″E / 41.770325°N 12.654044°E41.770325; 12.654044Coordinate: 41°46′13.17″N 12°39′14.56″E / 41.770325°N 12.654044°E41.770325; 12.654044 Religionecattolica TitolareMadonna delle Grazie Sede suburbicaria Albano ConsacrazioneXV secolo, 1954 Stile architettonicobarocco Inizio costruzioneXV secolo Completa...

 

Japanese politician Shintaro Ito伊藤 信太郎Minister of the EnvironmentIncumbentAssumed office 13 September 2023Prime MinisterFumio KishidaPreceded byAkihiro NishimuraMember of the House of RepresentativesIncumbentAssumed office 19 October 2001 - 21 July 200919 December 2012ConstituencyMiyagi 4th district(2001-2009, 2012-present) Personal detailsBorn (1953-05-06) 6 May 1953 (age 70)Tokyo, JapanPolitical partyLiberal Democratic PartyParentSoichiro Ito(father) Shintaro Ito (伊...

The article's lead section may need to be rewritten. Please help improve the lead and read the lead layout guide. (June 2021) (Learn how and when to remove this template message) His BeatitudePierre de CasaO.CarmTitular Latin Patriarch of JerusalemArchdioceseJerusalemProvinceJerusalemSeeJerusalemInstalled1345Term ended3 August 1348Personal detailsBorn1348LimogesDenominationRoman Catholic Styles ofPatriarch Pierre de CasaReference styleHis BeatitudeSpoken styleYour BeatitudeReligious styleMons...

 

District in An Giang, VietnamAn Phú district Huyện An PhúDistrictThe district is connected to the Mekong via the Hậu River. The district along the river served as a stop off point by traders on the way to Phnom Penh.Location in An Giang provinceCoordinates: 10°55′N 105°4′E / 10.917°N 105.067°E / 10.917; 105.067Country VietnamProvinceAn GiangCapitalAn PhúArea • Total87 sq mi (226 km2)Population (2014) • Tot...

 

Laya HealthcareTypePrivately ownedIndustryFinancial ServicesFounded1997; 26 years ago (1997)HeadquartersLittle Island, County Cork, IrelandProductsHealth InsuranceNumber of employees459 (2015)ParentBUPA (1997–2011)Independent (2011–15)AIG (2015–22)Corebridge Financial (2022–23)Axa (2023–present)Websitewww.layahealthcare.ie Laya Healthcare is a health insurance company in Ireland. Its headquarters are in Little Island, County Cork. It is regulated by the Health Insu...

Artikel ini memiliki beberapa masalah. Tolong bantu memperbaikinya atau diskusikan masalah-masalah ini di halaman pembicaraannya. (Pelajari bagaimana dan kapan saat yang tepat untuk menghapus templat pesan ini) Artikel atau sebagian dari artikel ini mungkin diterjemahkan dari Park Geun-hye di en.wikipedia.org. Isinya masih belum akurat, karena bagian yang diterjemahkan masih perlu diperhalus dan disempurnakan. Jika Anda menguasai bahasa aslinya, harap pertimbangkan untuk menelusuri referensin...

 

Chemical compound AM-630Legal statusLegal status CA: Schedule II DE: NpSG (Industrial and scientific use only) UK: Under Psychoactive Substances Act Identifiers IUPAC name 1-[2-(Morpholin-4-yl)ethyl]-2-methyl-3-(4-methoxybenzoyl)-6-iodoindole CAS Number164178-33-0 NPubChem CID4302963IUPHAR/BPS750ChemSpider3508738 YUNIIU1LNJ6NBKAChEMBLChEMBL181633 YCompTox Dashboard (EPA)DTXSID10167719 ECHA InfoCard100.229.964 Chemical and physical dataFormulaC23H25IN2O3Molar mass...

 

High speed train KTX-I (한국고속철도)KTX-I trainset 24 leaving Daejeon StationRefurbished 2nd class interiorManufacturerAlstom (trainsets 01–12)Rotem (trainsets 13–46)Family nameTGV[1]Constructed1997–2000 (trainsets 01–12)[2]2002–2003 (trainsets 13–46)[3]Entered service2004Number built46Number in service46FormationPC+MT+16IT+MT+PC[2] PC: power car (traction head) MT: motorized trailer (passenger car with one bogie powered) IT: intermediate tra...

Brazilian actor In this Portuguese name, the first or maternal family name is Junqueira Reis and the second or paternal family name is Santoro. Rodrigo SantoroSantoro at the 2017 San Diego Comic-ConBornRodrigo Junqueira Reis Santoro (1975-08-22) 22 August 1975 (age 48)Petrópolis, Rio de Janeiro, BrazilAlma materPontifical Catholic University of Rio de Janeiro (dropped out)OccupationActorYears active1993–presentSpouse Mel Fronckowiak ​(m. 2016)̴...

 

Zimbabwe ai Giochi olimpici Codice CIO ZIM Comitato nazionale Comitato Olimpico dello Zimbabwe Cronologia olimpica Giochi olimpici estivi 1980 · 1984 · 1988 · 1992 · 1996 · 2000 · 2004 · 2008 · 2012 · 2016 · 2020 Giochi olimpici invernali 2014 · 2018 · 2022 Altre apparizioni Rhodesia (1928-1964) Lo Zimbabwe ha partecipato per la prima volta ai Giochi olimpici nel 1980, prendendo parte a quelli estivi di Mosca e farà...

 

Wappen Deutschlandkarte 49.35805555555610.698055555556347Koordinaten: 49° 21′ N, 10° 42′ O Basisdaten Bundesland: Bayern Regierungsbezirk: Mittelfranken Landkreis: Ansbach Verwaltungs­gemeinschaft: Weihenzell Höhe: 347 m ü. NHN Fläche: 7,61 km2 Einwohner: 1332 (31. Dez. 2022)[1] Bevölkerungsdichte: 175 Einwohner je km2 Postleitzahl: 91590 Vorwahl: 09824 Kfz-Kennzeichen: AN, DKB, FEU, ROT Gemeindeschlüssel: 09 5...

Harvey McGregorCBE QCMcGregor in 1983Warden of New College, OxfordIn office1985–1996Preceded byArthur Hafford CookeSucceeded byAlan Ryan Personal detailsBorn25 February 1926Died27 June 2015(2015-06-27) (aged 89)EducationInverurie Academy Scarborough High School for BoysAlma materThe Queen's College, Oxford Harvey McGregor CBE QC (25 February 1926 – 27 June 2015) was a British barrister and academic, who was Warden of New College, Oxford from 1985 to 1996. Early life The son ...

 

Dans le nom hongrois Víg Mihály, le nom de famille précède le prénom, mais cet article utilise l’ordre habituel en français Mihály Víg, où le prénom précède le nom. Cet article est une ébauche concernant un compositeur hongrois. Vous pouvez partager vos connaissances en l’améliorant (comment ?). Pour plus d’informations, voyez le projet musique classique. Mihály VígBiographieNaissance 21 septembre 1957 (66 ans)BudapestNationalité hongroise...

 

Strategi Solo vs Squad di Free Fire: Cara Menang Mudah!