אליעד כהן
ייעוץ עסקי ואישי
בשיטת EIP
⭐⭐⭐⭐⭐
הדפסה לפתור שאלות ב leetcode ✔חידת LeetCode Solution - Block Placement Queries, פתרון ליטקוד, LeetCode Solution, לפתור שאלות ב LeetCode, מדעי המחשב,...
הצטרף לחברים באתר!
שם
סיסמא
לחץ כאן
להתחבר לאתר!
💖
הספרים שמומלצים לך:
להצליח בחיים
ולהיות מאושר!






☎️
ייעוץ אישי בכל נושא!
050-3331-331
🖶 חידת LeetCode Solution - Block Placement Queries, פתרון ליטקוד, LeetCode Solution, לפתור שאלות ב LeetCode, מדעי המחשב, תכנות מחשבים, לעבוד בהייטק, ללמוד תכנות מחשבים, להיות מתכנת, ללמוד לתכנת, הכנה לראיון טכני, ראיון עבודה בהייטק, שאלות ליטקוד, פיתוח תוכנה, איך לכתוב קוד? ללמוד לכתוב קוד, חידות היגיון, ללמוד לחשוב, ללמוד לנתח דברים, ללמוד לפרק לגורמים, ללמוד לחלק לחלקים, ללמוד למצוא חוקיות, איך לחלק לחלקים? איך למצוא חוקיות? לנתח תהליכים
והפעם נדבר על שאלת 3161. LeetCode - Block Placement Queries הבאה:
There exists an infinite number line, with its origin at 0 and extending towards the positive x-axis.

You are given a 2D array queries, which contains two types of queries:

For a query of type 1, queries[i] = [1, x]. Build an obstacle at distance x from the origin. It is guaranteed that there is no obstacle at distance x when the query is asked.

For a query of type 2, queries[i] = [2, x, sz]. Check if it is possible to place a block of size sz anywhere in the range [0, x] on the line, such that the block entirely lies in the range [0, x]. A block cannot be placed if it intersects with any obstacle, but it may touch it. Note that you do not actually place the block. Queries are separate.

Return a boolean array results, where results[i] is true if you can place the block specified in the ith query of type 2, and false otherwise.

Example 1:

Input: queries = [[1,2], [2,3,3], [2,3,1], [2,2,2]]

Output: [false,true,true]

Explanation:

For query 0, place an obstacle at x = 2. A block of size at most 2 can be placed before x = 3.

Example 2:

Input: queries = [[1,7], [2,7,6], [1,2], [2,7,5], [2,7,6]]

Output: [true,true,false]

Explanation:

Place an obstacle at x = 7 for query 0. A block of size at most 7 can be placed before x = 7.

Place an obstacle at x = 2 for query 2. Now, a block of size at most 5 can be placed before x = 7, and a block of size at most 2 before x = 2.
אז קודם כל נסביר את השאלה שהולכת כך:

נתון לפנינו: ציר קו באורך אין סופי, שמתחיל ב 0 וממשיך ב 1,2,3 וכולי עד אין סוף.

כמו כן נותנים לנו רשימה של שאילתות, שמורכבת מ 2 סוגים של שאילתות:

סוג 1 של שאילתה, אומר לנו לשים "מחסום" בנקודה X בקו שלנו.

סוג 2 של שאילתה, שואל אותנו, האם ניתן לשים על הציר שלנו, "בלוק" ברוחב כלשהו, החל מ 0 ועד לנקודה X כלשהי. כאשר המחסומים שהצבנו בגלל שאילתה מספר 1, מגבילים את היכולת שלנו לשים "בלוקים" במיקום של המחסומים.


שאילתה מסוג 1, מוצגת כך:

queries[i] = [1, x]

כאשר הספרה הראשונה היא 1, זה אומר שמדובר על שאילתה מסוג 1, שאומרת לנו להציב מכשול במקום X כנ"ל. הבהרה: המכשול עצמו תופס 0 מקום.

לדוגמא:

queries[i] = [1, 10]

פירושו, תציב מכשול בנקודה 10 על ציר המספרים. כאשר המכשול עצמו לא תופס מקום.





שאילתה מסוג 2 מוצגת כך:

queries[i] = [2, x, sz]

כאשר הספרה הראשונה היא 2, זה אומר שמדובר על שאילתה מסוג 2, ששואלת אותנו, האם ניתן להציב בלוק ברוחב SZ עד למיקום X

לדוגמא:

queries[i] = [2, 5, 6]

השאילתה שואלת אותנו, האם ניתן להציב בלוק ברוחב 6, החל ממיקום 0 ועד למיקום 5. והתשובה היא, שלא. כי עד למיקום 5, ניתן להציב אך ורק בלוק עד רוחב 5 אך לא יותר מכך.





או לדוגמא:

queries[i] = [2, 5, 3]

השאילתה שואלת אותנו, האם ניתן להציב בלוק ברוחב 3, החל ממיקום 0 ועד למיקום 5. והתשובה היא, שכן. כי עד למיקום 5, ניתן להציב כל בלוק עד רוחב 5.





ואם לדוגמא אמרנו לנו את זה

queries[0] = [1, 10]

queries[1] = [2, 15, 12]

אז השאילתה הראשונה תאלץ אותנו לשים מכשול במקום 10 על גבי הציר. כך:





ואז לא נוכל לשים מכשול ברוחב 12, עד למיקום 15. כי המכשול שנמצא במיקום 10, מגביל אותנו לשים מכשול ברוחב 12 החל ממיקום 0, כי המכשול יתנגש במחסום שיש במיקום 10.





ואם עכשיו ישאלו אותנו:

queries[2] = [2, 10, 9]

דהיינו, האם עד מקום 10, ניתן לשים מכשול ברוחב 9, התשובה תהיה שכן

וגם אם ישאלו

queries[3] = [2, 10, 10]

דהיינו, האם עד מקום 10, ניתן לשים מכשול ברוחב 10, התשובה תהיה שכן

כך:





ואם עכשיו יגדירו לנו

queries[4] = [1, 7]

דהיינו, יבקשו מאיתנו לשים מכשול נוסף גם במקום 7, כך:





הרי שאם ישאלו אותנו עכשיו שוב פעם לדוגמא את זה:

queries[5] = [2, 10, 10]

דהיינו, האם עד מקום 10, ניתן לשים מכשול ברוחב 10, התשובה תהיה שלא. כי מאחר שכבר יש מכשול במקום 7, אז לא ניתן לשים בלוק עד מקום 10

כך:





דהיינו, מה שהיה אפשרי קודם, לשים בלוק ברוחב 10 עד מיקום 10, כי המכשול שנמצא ב 10, לא תופס מקום כנ"ל. ולכן קודם זה כן היה אפשרי. אבל כרגע בגלל שכבר יש מכשול במקום 7, הרי שלא ניתן לשים מכשול ברוחב 10, עד מיקום 10.

חידוד: הצבת המחסומים היא מצטברת. ולכן יתכן שאותה שאילתה מסוג 2, פעם אחת תהיה אפשרית ולאחר מכן היא לא תהיה יותר אפשרית, מאחר שהוגבלנו על ידי הצבת מחסום כלשהו.


ובהינתן לדוגמא הגדרת המכשולים האלו:





אז אם נשאל, האם ניתן ממקום 0 ועד מקום 17, לשים מכשול ברוחב 5? התשובה תהיה שכן, כי ניתן לשים את המכשול, בטווח שבין 3 לבין 9 כך:





אז מה בעצם שואלים אותנו?

אז השאלה הולכת כך: נותנים לנו רשימה של שאילתות, חלקן מסוג 1, דהיינו, שאילתות שמגדירות לנו היכן למקם מחסומים. כמו כן חלק מהשאילתות, הן מסוג 2, דהיינו, הן שואלות אותנו, האם בהתאם למחסומים שהצבנו עד כה על גבי ציר המספרים, האם עד כה ניתן למקום את הבלוק ברוחב מוגדר כלשהו, עד למיקום X כלשהו.

כאשר כל שאילתה מסוג 2, עומדת בפני עצמה. דהיינו, לצורך העניין אחרי שמציבים בלוק ברוחב כלשהו, מסירים אותו. והוא לא מגביל את הצבת הבלוק הבא.

וכנ"ל, הצבת המחסומים היא מצטברת. ולכן יתכן שאותה שאילתה מסוג 2, פעם אחת תהיה אפשרית ולאחר מכן היא לא תהיה יותר אפשרית, מאחר שהוגבלנו על ידי הצבת מחסום כלשהו.

ובעצם השאלה היא, בהינתן לנו רשימת שאילתות, עלינו להחזיר תשובה של: אפשרי או לא אפשרי, עבור כל אחת מהשאילתות מסוג 2 כנ"ל.


ולכאורה, זאת התשובה לשאלת הליטקוד הזאת, היא מאוד מאוד מאוד פשוטה. כי בתכלס, אפשרי לקחת נייר ולרשום את כל המחסומים. וכאשר שואלים אותנו, האם ניתן להציב בלוק ברוחב כלשהו, עד למיקום X, בסך הכל נצטרך לבדוק מ 1 ועד X, האם יש את הרוחב הרצוי להצבת הבלוק.

כך שמצד האמת, התשובה לשאלת ליטקוד הזאת היא מאוד פשוטה. אז מהי בעצם השאלה? ולמה השאלה הזאת, נחשבת לשאלת ליטקוד מאוד מאוד קשה?

והתשובה היא, שעיקר השאלה היא, איך לעשות את החישובים הנ"ל בצורה יעילה. כי לבדוק בכל פעם של שאילתה מסוג 2, החל מ 1 ועד X, האם קיים רוחב SIZE כלשהו, זה פתרון שבמאה אחוז עובד, אבל ממש לא יעיל.

למה הוא לא יעיל? ממגוון רחב מאוד של סיבות. כי נניח שישאלו אותנו, האם ניתן להציב עד מיקום 100,000,000 בלוק ברוחב 13,522. ונניח שעד מיקום 100,000,000 יש לנו 9,999 מכשולים במקומות שונים. האם באמת הגיוני שאנחנו נצטרך עכשיו לספור 100,000,000 מקומות, כדי לדעת אם אפשרי או לא אפשרי להציב את המכשול ברוחב SIZE עד למיקום X? זה כנראה מתיש ולא יעיל...

ולכן מהות השאלה היא, מהי הדרך היעילה ביותר כדי לתת תשובה לשאילתה מסוג 2. זאת מהות השאלה.


אז חלק גדול מהפתרונות שהוצעו לשאלה הזאת, עובדים עם לוגיקה של segment tree. דהיינו, מבנה נתונים מסוג "עץ מקטעים" ולא ניכנס כאן כרגע לכיוון הזה של הפתרון. אבל אני כן אציג בדרך של מחוייב ואפשרי, מה בטוח נכון, לחלק לחלקים וכולי, כיצד ניתן לפתור את השאלה הזאת...


אז איך ניגשים לשאלה הזאת? איך מנסים למצוא פתרון יותר יעיל לשאלה הזאת.

אז נתחיל בפתרון הכי לא יעיל שיש וממנו ננסה לשפר. אז מהו הפתרון הכי לא יעיל. הפתרון הכי לא יעיל יהיה, שעלינו לעבור מיקום מיקום, החל מ 1 ועד X, ולנסות למצוא SIZE מקומות פנויים בלי מכשולים באמצע. כאשר אם הגענו למכשול ועדיין לא הגענו לרוחב SIZE, אז עלינו להתחיל את הספירה של המיקומים מחדש. עד שנגיע למספר X או עד שנמצא מיקומים ברוחב SIZE פנויים. ואז נוכל לדעת אם אפשרי או לא אפשרי להכניס בלוק ברוחב SIZE עד למיקום X.

ובמילים אחרות, הפתרון הכי לא יעיל, יהיה לעבור מיקום מיקום אחד אחד מההתחלה ועד X כנ"ל.

ואיך ניתן לשפר את הפתרון הזה בדרך יחסית יעילה?

נוכל לשאול את עצמנו, מה בטוח נכון. דהיינו, בכל פעם שיגדירו לנו לשים מכשול במיקום כלשהו, אנחנו נכתוב לנו את הרוחב הפנוי שיש בין מכשול למכשול כך:





וכך במקום לעבור מיקום מיקום ולחפש רוחב כלשהו של מקומות פנויים, פשוט נעבור על הגדלים של הטווחים שיש בין מכשול למכשול, וככה בעצם כבר חסכנו לעצמנו המון פעולות חיפוש...

אבל האם באמת זאת הדרך היעילה ביותר? האם באמת בכל פעם נצטרך לעבור על כל הטווחים של כל המכשולים, בכל פעם מחדש מההתחלה ועד X?

אז איך נתקדם מכאן?

אז אם נתבונן נראה, שבעצם אנחנו מחפשים למצוא דרך, איך נוכל בדרך הקצרה ביותר, לדעת, על מיקום כלשהו בציר המספרים שלנו, מהו הטווח הגדול ביותר שניתן להציב בתוכו בלוק ברוחב כלשהו. ואיך ניתן לעשות זאת בכמה שפחות פעולות.

לדוגמא: נניח ששואלים אותנו האם עד מיקום 1M ניתן להציב מכשול ב SIZE של 2000 כאשר יש לנו 5000 מכשולים שונים.

אז, בדרך הארוכה ביותר, היינו יכולים לעשות במקרה הגרוע ביותר 1M פעולות, כדי לעבור על כל המקומות ברשימת המספרים.

בפתרון הקודם שהצענו, הרי שאם יש לנו 5000 מכשולים, הרי שיש לנו 5000 טווחים של גדלים שבהם ניתן להכניס בלוקים ברוחב כלשהו. והרי שכך במקרה הגרוע ביותר נרוץ על 5000 מכשולים שונים, עד שנגלה אם אפשרי או לא אפשרי להכניס את הבלוק ברוחב 2000 הנדרש כנ"ל.

אבל האם זה הכרחי, לרוץ על 5000 טווחים, החל מהטווח הראשון ועד האחרון? אולי יש דרך שנוכל לסמן לנו בכל מיקום, מהו הטווח הגדול ביותר שניתן להכניס אליו בלוקים, עד אותו מיקום? האם יש אפשרות כזו? איך מבצעים אותה?


אז עקרונית, בכל פעם שנותנים לנו הגדרה של מכשול כלשהו, אנחנו יכולים לעבור על כל רשימת המיקומים, החל ממיקום 1 ועד למיקום של המכשול האחרון, ולסמן לעצמנו על כל מיקום, מה הרוחב המקסימאלי שיכול להיכנס עד אותו המיקום. לדוגמא כך:





הדרך הזאת, תהיה מאוד יעילה עבור החיפושים עצמם, כי בתוך שניה נוכל לדעת מהו הרוחב המקסימאלי שניתן להכניס עד למיקום X. החיסרון של הדרך הזה יהיה, שנצטרך לעדכן בכל פעם מחדש את כל המיקומים שמושפעים מכל מכשול חדש.

נניח בדוגמא הנ"ל, שיוסיפו לנו עוד מכשול במיקום 7, הרי שנצטרך לעדכן מחדש את כל הרשימה כך:





מה שאומר בעצם, שבדרך הפתרון הזו, אנחנו נעשה המון פעולות מסוג עדכון שיעזרנו לנו אומנם בפעולות מסוג חיפוש, אבל עדיין יקשו עלינו לעשות המון פעולות עדכון.

ונחדד, נניח שנבחר באפשרות של לשמור בכל מיקום כולל כל מיקום, את הרוחב המקסימאלי האפשרי עד לאותו מיקום, הרי שעדיין נצטרך לשאול את עצמנו, מה תהיה הדרך היעילה ביותר לעדכן את כל המיקומים בכל פעם מחדש. וזאת גם שאלה בפני עצמה.


אז אולי אפשרי שנקצר את פעולות העדכון בדרך הבאה: אולי במקום לעדכן את כל המיקומים עצמם, אולי נוכל לעדכן בכל פעם מחדש, את כל המיקומים של המכשולים בלבד, לדוגמא כך:





דהיינו, אולי ננסה לשמור על גבי כל מיקום של כל מכשול, את הרוחב המקסימאלי האפשרי שקיים עד אותו המכשול.

ונחדד, נניח שנבחר באפשרות של לשמור רק בכל מיקום של מכשול, את הרוחב המקסימאלי האפשרי עד לאותו מכשול, הרי שעדיין נצטרך לשאול את עצמנו, מה תהיה הדרך היעילה ביותר לעדכן את כל המיקומים של המכשולים בכל פעם מחדש. וזאת גם שאלה שאנחנו צריכים להתבונן בה.


אז איך בעצם ניגש לזה?

ונחדד: יש לנו כאן 2 סוגים של שאילתות. שאילת 1 של הגדרת מכשולים. ושאילתה 2 של בקשת מידע בהתאם להגדרת המכשולים.

וזה בעצם אומר, שיש לנו כאן כמה תהליכים נפרדים:

נניח לדוגמא שנתון לנו הציר הבא, עם החישובים הבאים:





אז יכולים להיות לנו כמה תהליכים, לדוגמא:

תהליך 1 - הגדרת המכשול במיקום X

לדוגמא: שים מכשול חדש במיקום 9





תהליך 2 - הגדרת טווח רוחב אפשרי מעודכן, מצד ימין ומצד שמאל של המכשול החדש





תהליך 3 - עדכון רוחב הטווח המקסימאלי בכל מיקום של מכשול כנ"ל





תהליך 4 - חישוב של האם ניתן לשים מכשול ברוחב כלשהו, עד למיקום X, בהתאם לרשימת הטווחים המקסימאלית עד לכל מכשול, כנ"ל בתהליך 3.

דהיינו, אם עכשיו לדוגמא ישאלו אותנו, האם ניתן לשים מכשול עד לנקודה 17 ברוחב 5, הרי שנצטרך לבצע את החישוב, לפי המידע שיש לנו על המכשול שנמצא במיקום 14 כנ"ל. והתשובה תהיה שכן.

או אם לדוגמא ישאלו אותנו, האם ניתן עד מיקום 12 לשים מכשול ברוחב 6, נצטרך לבצע את החישוב בהתאם למכשול שנמצא במיקום 9, והתשובה תהיה כן, כנ"ל.

וגם תהליך 4 עצמו, מורכב מכמה חלקים.

חלק 1 - לאתר את המכשול הקרוב ביותר לנקודה שעליה אנחנו נשאלים.

חלק 2 - לבצע את החישוב כדי למצוא תשובה למה ששאלו אותנו, על בסיס המידע שיש לנו על המכשול שמצאנו. (כי את המידע אנחנו שומרים על המכשול ולא על כל מיקום בפני עצמו).

ובאופן כללי יש כאן כל מיני תהליכים נוספים, כגון של:

1 - ניהול הרשימה של המכשולים

2 - לוודא שרשימת המכשולים ממויינת, בהתאם למיקומים של המכשולים על גבי הציר ולא לפי סדר ההכנסה שלהם לרשימה.

3 - לוודא שבכל מיקום של כל מכשול, נשמר עליו המידע של המיקום שלו על גבי הציר, של הטווח שלו מהמכשול שתחתיו, של הטווח המקסימאלי האפשרי עד אליו וכיו"ב.

דהיינו, יש כאן כל מיני תהליכים שונים.


כמו כן אציין, שיש כל מיני מקרי קצה, שאפשרי לפתור אותם יחסית בקלות, אבל אני בוחר שלא להתייחס אליהם כרגע.

לדוגמא, שלא משנה מה, תמיד לא תהיה אפשרות להכניס בלוק ברוחב SIZE אם הרוחב גדול מהמיקום עצמו. לדוגמא, לא ניתן להכניס בלוק ברוחב 100, עד מיקום 99 וכיו"ב.

או לדוגמא, שתמיד תהיה אפשרות להכניס בלוק ברוחב SIZE אם X גדול מהמיקום של המכשול האחרון + SIZE. לדוגמא, תהיה אפשרות להכניס מכשול ברוחב 10, למיקום 100, אם המכשול הגדול ביותר נמצא במיקום 70.

או כל מיני חישובים מהירים כאלו ואחרים, שאם יש 2 מכשולים בלבד, ברוחב כלשהו, הרי שמכך נוכל להסיק ששום רוחב לא יהיה קטן או גדול מ רוחב כלשהו וכיו"ב. לדוגמא 2 מכשולים על רוחב 1000, לא יוכלו לחסום את כל הבלוקים שהם ברוחב 100.

בקיצור, יש גם כל מיני מקרי קצה שאני לא רוצה להיכנס אליהם כרגע.

יש גם עניין של אפשרות להסיק מהשאילתות מסוג 2 הקודמות לשאילתה הנוכחית, במידה ולא היו שאילתות מסוג 1 ביניהן. לדוגמא, אם שאלו אותנו שאלה על מיקום 1000, ומיד אחר כך שאלו אותנו שוב שאלה על מיקום 1000 או אולי על מיקום 2000, אולי נוכל להסיק מהשאילתה הקודמת על השאילתה הנוכחית וכיו"ב. דהיינו, כל מיני מקרים פרטיים ולוגיקות ספציפיות.


כמו כן אני אוסיף, כי מאחר שיש כאן כל מיני תתי תהליכים, הרי שברמת העיקרון אפשרי לשקול מתי לבצע את פעולת ה עדכון של הטווח המקסימאלי האפשרי. האם לבצע אותו אחרי כל שאילתה מסוג 1. או אולי לפני כל שאילתה מסוג 2.

או אולי זה בכלל יהיה קשור למיקום של העדכון של 1, ביחס לשאילתה של 2. לדוגמא שאילתה מסוג 1 על מיקום 1000, לא תשפיע על שאילתה מסוג 2 על מיקום 500.

וזה קשור גם לכמות השאילתות מסוג 1 ומסוג 2. וגם קשור להאם השאילתות מסוג 1 רצופות אחת אחרי השניה או לא. כי לדוגמא, אפשרי אולי לבצע פעולת עדכון אחת, אחרי כמה שאילתות מסוג 1 של הצבת מכשולים.

בקיצור, יש כאן כל מיני זוויות והיבטים לתקוף את הנושא הזה.

אבל כרגע אני בוחר להתמקד בעניין של תהליך העדכון של הטווח המקסימאלי האפשרי, עד למיקום X.

דהיינו, ננסה למצוא דרך פשוטה איך אפשרי לעדכן יחסית בקלות, את כל המכשולים שהוצבו, בטווח ברוחב המקסימאלי, עד לאותו המכשול.

כאשר בעצם מהות השאלה היא, איך ניתן לחשב במיקום של מכשול X, את הרוחב המקסימאלי האפשרי עד לאותו המיקום, בדרך הקלה ביותר, לעדכן את המידע הזה.

אז איך ניגשים לזה?


אז כדי לדעת איך לפתור את הבעיה, לשם כך עלינו לנסות לחלק את הבעיה לחלקים הכי קטנים שיש, לחפש מה בטוח נכון, לנסות למצוא חוקיות, ואחר כך לנסות לחשוב על נוסחה ופתרון.

אז כמו שאמרנו כרגע ננסה להתמקד אך ורק בלנתח, איך הכי נכון לעדכן את רשימת המכשולים, במידע של מהו הטווח ברוחב המקסימאלי, עד לאותה נקודת מכשול.

כי כמו שאמרנו, יש כאן כל מיני תהליכים. ואחד התהליכים הוא, להחזיק רשימה של מהו הטווח המקסימאלי, עד לנקודה X. כדי לחסוך לנו לחפש בכל פעם מחדש מהתחלת הציר ועד ל X, את הטווח המקסימאלי. ולשם כך, נרצה להחזיק את הטווח המקסימאלי עד לנקודה X.

וכמו שאמרנו, יש אפשרות לנסות להחזיק את המידע, עבור כל הנקודות בציר גם כאלו שאין בהן מכשול כלשהו. ויש גם אפשרות לנסות להחזיק את המידע הזה, רק עבור הנקודות שבהן נמצא מכשול על גבי הציר.

ואני מפריד בין השאלות של: האם מתי כמה ולמה לעדכן את המידע של מהו הטווח המקסימאלי עד לנקודת מכשול כלשהי, לבין השאלה של איך לעדכן בצורה הכי יעילה את המידע הזה, של מהו ה MAX RANGE עד למכשול כלשהו. ומהמידע הזה, נוכל ללמוד על כל נקודה אחרת בציר, שאין בה מכשול.

כמו כן, אני עושה הפרדה בין השאלה של איך לנהל בפועל את הרשימה של המכשולים. כי גם את זה צריך לעשות, לדוגמא: צריך לוודא שהרשימה תהיה ממוינת לפי המיקום של המכשולים על גבי הציר ולא לפי סדר הצבת המכשולים. וכרגע לא נתמקד בזה, אלא רק באיך לעדכן את רשימת המכשולים.

כמו כן, אנחנו נניח שננהל את הרשימה עצמה, בתוך מבנה של רשימה פשוטה ורגילה. ולא בצורה של עץ טווחים (segment tree) שזה עוד נושא בפני עצמו.

ולכן נשאל: נניח שאנחנו רוצים לנהל רשימה של כל המכשולים בצורה של רשימה ולא של עץ או של משנה אחר. ונניח שהרשימה הזאת של המכשולים, ממוינת לפי סדר המכשולים על גבי הציר. ונניח שאנחנו רוצים בכל פעם לעדכן אותה, במידע של מהו הטווח המקסימאלי, שאפשרי להציב בלוק, החל מהתחלת הציר ועד לנקודת מכשול כלשהי, אז כיצד יהיה הכי יעיל לעשות את זה?


אז לשם כך נתחיל לחלק לחלקים לחלק הקטן ביותר, והוא כמובן יהיה ציר ריק בלי שום מכשולים כלשהם. זהו כמובן המקרה הפשוט ביותר. כך:





אז לצורך העניין נתבונן על ציר ריק ללא מכשולים, ונשאל: מהו גודל הבלוק המקסימאלי שניתן להציב עד נקודה מספר 1? תשובה: בלוק ברוחב של 1.

ועד נניח למיקום 7, איזה גודל מקסימאלי של בלוק, ניתן להציב? תשובה: 7. כי עד מיקום 7, לא ניתן להכניס בלוק יותר רחב מהרוחב של המיקום הנוכחי.

במילים אחרות, לצורך העניין ניתן לדמיין שיש לנו בלוק בנקודה 0, שמגביל אותנו לכך שלא נוכל להכניס עד נקודה X, שום מכשול שהוא יותר גדול מנקודה X.





עד כאן זה משהו שהוא הכי פשוט שיש ושהוא בטוח נכון.


ומה נוכל להסיק מכך שהוא בטוח נכון, על מקרה שהוא קצת יותר מורכב?

תשובה: מכך נוכל להסיק לגבי מקרה של ציר, שיש עליו רק מכשול 1 בלבד. לדוגמא מכשול 1 בלבד במיקום 5:





נוכל להסיק בוודאות, כי כאשר מגדירים לנו את המכשול הראשון, אנחנו יכולים לדעת בוודאות של מאה אחוז, שעד המכשול הראשון, לא ניתן להכניס שום בלוק, שהוא גדול יותר מהמיקום של המכשול הראשון.

לדוגמא: אם המכשול הראשון הוא במיקום 5, הרי שמכך נובע, שעד המכשול הראשון במיקום עד, הטווח והגודל המקסימאלי של בלוק שניתן להכניס, יהיה בגודל 5 בלבד.

ולכן מכך נובע, שכאשר יתנו לנו את המכשול הראשון, נרשום לידו, שה MAX RANGE המקסימאלי עד אליו, הוא המיקום של אותו X כנ"ל.


עכשיו נתבונן רגע אחד על המקרה הקודם, ונשאל: מה...
בגלל משנה חסכנות למה הוא לא לנתח מהי הדרך האם קיים וודאות של מאה אחוז תשובה דרך קצרה מה יקרה אם leetcode leetcode solution איך לחלק לחלקים איך לכתוב איך לכתוב קוד איך למצוא איך למצוא חוקיות גורמים היגיון הייטק הכנה ל הכנה לראיון הכנה לראיון טכני חוקיות חידה חידות חידות היגיון חידת leetcode חידת היגיון חשיבה מדעית טכני לגורמים להיות מתכנת להתראיין לחלק לחלקים לחשוב ליטקוד לכתוב לכתוב קוד ללמוד ללמוד לחלק ללמוד לחלק לחלקים ללמוד לחשוב ללמוד לכתוב ללמוד לכתוב קוד ללמוד למצוא ללמוד למצוא חוקיות ללמוד לנתח ללמוד לנתח דברים ללמוד לפרק ללמוד לפרק לגורמים ללמוד לתכנת ללמוד תכנות ללמוד תכנות מחשבים למידה למצוא למצוא חוקיות לנתח לנתח דברים לנתח תהליך לנתח תהליכים לעבוד לעבוד בהייטק לפרק לפרק לגורמים לפתור לפתור שאלות לפתור שאלות ב leetcode לפתח לראיין לראיין עובד לראיין עובדים לשאול שאלות לתכנת מדע מדעי המחשב עבודה עבודה בהייטק פיתוח פיתוח תוכנה פתרון פתרון ל פתרון ליטקוד ראיון ראיון טכני ראיון עבודה ראיון עבודה בהייטק ראיונות שאלות שאלות ליטקוד תהליך תהליכים תכנות תכנות מחשבים
ליטקוד, LeetCode Solution, איך לפתור שאלות ב LeetCode? ראיונות קוד, תרגול ליטקוד, מדעי המחשב, תכנות מחשבים, לעבוד בהייטק, ראיון טכני, שאלות חשיבה, איך לפתור בעיות מורכבות? איך לפתח את המוח? איך להתכונן לראיון עבודה בהייטק? תרגול שאלות ליטקוד כהכנה לראיון, איך להיות מתכנת מחשבים? לעבוד בפיתוח תוכנה, איך למצוא מה בטוח נכון? ללמוד לנתח תהליכים, איך ללמוד לתכנת? איך ללמוד לכתוב קוד? כתיבת קוד, לפתור חידות היגיון, איך להבין חוקיות? איך למצוא חוקיות?
...הפתרון שהצענו לפתור את השאלה, יפתור אותה בכל המצבים האפשריים שהאתר LeetCode יבדוק את הפתרון שלנו. כי בצוות של האתר ליטקוד, יש אנשים שלוקחים פתרונות של אנשים ומנסים להקריס את הפתרונות האלו בכל מיני מקרה קצה כאלו ואחרים. ולפתור את השאלה מבחינת ליטקוד, זה רק כאשר הפתרון שלנו עובר את כל מצבי הבדיקה TestCase שהם הגדירו לבדוק את הפתרון שלנו. או במילים אחרות, זאת לא רק חוכמה לדעת לפתור שאלות בליטקוד, אלא זאת גם חוכמה להבין איך לפתור את השאלה בכל מצב אפשרי...
חידת LeetCode Solution - Candy, פתרון ליטקוד, LeetCode Solution, איך לפתור שאלות ב LeetCode? איך לפתור חידת LeetCode? מדעי המחשב, תכנות מחשבים, איך להתקבל לעבוד בהייטק? איך ללמוד תכנות מחשבים? איך להיות מתכנת? איך לעבור ראיון טכני? איך להתכונן לראיון עבודה בהייטק? תרגול שאלות ליטקוד כהכנה לראיון, איך להיות מתכנת מחשבים? איך לעבוד בפיתוח תוכנה? איך להתכונן לראיונות כתיבת קוד? איך לפתור חידת היגיון? חידות היגיון, איך לעבור ראיון עבודה טכני?
...מקום 10 (דירוג 2 = כמות 1) ואז נחזור לנסות לגזור ממנו וודאות לגבי מקום 9 ונציב במקום 9 4, כדי שהוא יהיה גדול מהכמות של מקום 8. וכך שוב קיבלנו את הפתרון הקודם שהוא מקום 01 (דירוג 7 = כמות 2) מקום 02 (דירוג 6 = כמות 1) מקום 03 (דירוג 6 = כמות 4) מקום 04 (דירוג 5 = כמות 3) מקום 05 (דירוג 4 = כמות 2) מקום 06 (דירוג 0 = כמות 1) מקום 07 (דירוג 1 = כמות 2) מקום 08 (דירוג 2 = כמות 3) מקום 09 (דירוג 3 = כמות 4) מקום 10 (דירוג 2 = כמות 1) ועכשיו נזכיר שיש...
חידת LeetCode Solution - Trapping Rain Water, פתרון ליטקוד, LeetCode Solution, איך לפתור שאלות ב LeetCode? איך לפתור חידת LeetCode? מדעי המחשב, תכנות מחשבים, איך להתקבל לעבוד בהייטק? איך ללמוד תכנות מחשבים? איך להיות מתכנת? איך לעבור ראיון טכני? איך להתכונן לראיון עבודה בהייטק? תרגול שאלות ליטקוד כהכנה לראיון, איך להיות מתכנת מחשבים? איך לעבוד בפיתוח תוכנה? איך להתכונן לראיונות כתיבת קוד? איך לפתור חידת היגיון? חידות היגיון
...1. דהיינו, סהכ 6 קוביות מים. אז איך ניגשים לפתור את השאלה הזאת? בהינתן לנו רשימת גבהים של עמודים, איך נוכל לדעת כמה מים יכנסו בין העמודים האלו? איך ניגשים לזה? אז בתור התחלה ננסה לחלק את השאלה לחלקים. אז מה בעצם שואלים אותנו? נותנים לנו רשימת מספרים. כל מספר מייצג גובה של עמוד. אנחנו אמורים לחשב את הכמות הכללית של כל המים שיכולים להיות כלואים בין העמודים. אז בעצם כדי לפתור את השאלה הזאת, לשם כך יש לנו לבצע כמה שלבים. שלב 1 יהיה לחשב האם וכמה מים...
חידת LeetCode Solution - Minimum Reverse Operations, פתרון ליטקוד, LeetCode Solution, איך לפתור שאלות ב LeetCode? איך לפתור חידת LeetCode? מדעי המחשב, תכנות מחשבים, איך להתקבל לעבוד בהייטק? איך ללמוד תכנות מחשבים? איך להיות מתכנת? איך לעבור ראיון טכני? איך להתכונן לראיון עבודה בהייטק? תרגול שאלות ליטקוד כהכנה לראיון, איך להיות מתכנת מחשבים? איך לעבוד בפיתוח תוכנה? איך להתכונן לראיונות כתיבת קוד? איך לפתור חידת היגיון? חידות היגיון
...בשום היפוך, כי מקדם ההיפוך הוא 1 בלבד שלא מאפשר להזיז את הערך 1 ממקום למקום. ונעשה עוד בדיקה עם מערך באורך 10, כאשר המיקום ההתחלתי הוא 5 והמקדם היפוך הוא 1 ונקבל את זה: בשורה התחתונה, אנחנו מבינים בוודאות שמקדם היפוך 1, לא יכול להזיז את הערך 1 מהמקום ההתחלתי שלו P לשום מקום אחר. ולכן כל הערכים של ANS יהיו - 1, כי הערך 1 לא יכול לעבור אליהם. למעט כמובן המיקום ההתחלתי שהוא P. אז עד עכשיו בדקנו מקדם היפוך K = 1, ב3 מצבים. במצב של אורך N= 1 אורך N= 2...
חידת LeetCode Solution - Strong Password Checker, פתרון ליטקוד, LeetCode Solution, לפתור שאלות ב LeetCode, מדעי המחשב, תכנות מחשבים, לעבוד בהייטק, ללמוד תכנות מחשבים, להיות מתכנת, ללמוד לתכנת, הכנה לראיון טכני, ראיון עבודה בהייטק, שאלות ליטקוד, פיתוח תוכנה, איך לכתוב קוד? ללמוד לכתוב קוד, חידות היגיון, ללמוד לחשוב, ללמוד לנתח דברים, ללמוד לפרק לגורמים, ללמוד לחלק לחלקים, ללמוד למצוא חוקיות, איך לחלק לחלקים? איך למצוא חוקיות? איך לנתח תהליכים?
...ונצטרך לבדוק אותה אל מול 3 החוקים הנל, קודם כל נעדיף לבדוק את החוק של האורך, שהוא מספק לנו וודאות של מאה אחוז, גם לגבי כמות הפעולות וגם לגבי סוג הפעולות. אחר כך נבדוק את החוק של התווים ההכרחיים, שמספק לנו וודאות לגבי כמות ופחות לגבי סוג. ורק אחר כך נבדוק את החוק של התווים הרצופים, שמספק לנו הכי פחות וודאות לגבי כמות או סוג הפעולות שעלינו לבצע. מהי החוקיות של הפעולות עצמן? מה היחס ביניהן? ואם נעמיק עוד קצת לגבי הפעולות האפשריות לתקן סיסמא, וננסה לשאול...
חידת LeetCode Solution - Minimum Cost to Equalize Array, פתרון ליטקוד, LeetCode Solution, לפתור שאלות ב LeetCode, מדעי המחשב, תכנות מחשבים, לעבוד בהייטק, ללמוד תכנות מחשבים, להיות מתכנת, ללמוד לתכנת, הכנה לראיון טכני, ראיון עבודה בהייטק, שאלות ליטקוד, פיתוח תוכנה, איך לכתוב קוד? ללמוד לכתוב קוד, חידות היגיון, ללמוד לחשוב, ללמוד לנתח דברים, ללמוד לפרק לגורמים, ללמוד לחלק לחלקים, ללמוד למצוא חוקיות, איך לחלק לחלקים? איך למצוא חוקיות? לנתח תהליכים
...הערך MIN, שהיא העמודה עם המספר הקטן ביותר, שבה אנחנו צריכים לבצע את כמות ההגדלות הגדולה ביותר. עכשיו, יתכן שיש כמה עמודות עם הערך MIN. בדיוק כמו שיתכן שיש כמה עמודות עם הערך MAX. אבל לצורך העניין כרגע זה לא מעניין אותנו. כן מעניין אותנו לאתר את הערך MIN. שבו בעצם צריכים לבצע מקסימום פעולות הגדלה כדי להביא אותו לערך MAX. עכשיו, אם ננתח בצורה ידנית המון מקרים, נראה כי בעצם בהינתן רשימת מספרים כלשהי, הרי שיש לנו עמודה אחת או יותר של הערך MAX. ויש לנו...
איך לגרום למישהו להסכים איתך? ניהול דיונים, איך ליצור הסכמה? איך יוצרים הסכמה? איך לגרום למישהו להבין אותך? איך לפרק לגורמים רעיון מורכב? לא מסכימים על שום דבר, איך לגרום לה להסכים איתך? איך לגרום לו להסכים איתך? איך להסביר את עצמי?
איך לגרום למישהו להסכים איתך? ניהול דיונים, איך ליצור הסכמה? איך יוצרים הסכמה? איך לגרום למישהו להבין אותך? איך לפרק לגורמים רעיון מורכב? לא מסכימים על שום דבר, איך לגרום לה להסכים איתך? איך לגרום לו להסכים איתך? איך להסביר את עצמי?
... לגרום למישהו להסכים איתך? ניהול דיונים, איך ליצור הסכמה? איך יוצרים הסכמה? איך לגרום למישהו להבין אותך? איך לפרק לגורמים רעיון מורכב? לא מסכימים על שום דבר, איך לגרום לה להסכים איתך? איך לגרום לו להסכים איתך? איך להסביר את עצמי? איך לגרום למישהו ... שכאשר אדם אומר משפט כמו יש פה שולחן, הוא צריך להבין תחילה מה הסיבות שבגללן הוא חושב את המחשבה הזו. לדבריו, כדי שמישהו יסכים איתך, אתה צריך לפרק את הרעיון שלך לחלקים קטנים ככל הניתן, ולהגיע להסכמה על כל אחד מהחלקים בנפרד. למשל, כשאתה אומר למישהו: אתה מסכים איתי שיש פה שולחן?, והוא לא מסכים או לא מבין אותך, אתה צריך לבדוק מה בדיוק אתה אומר כאן ולמה אתה חושב כך. אתה צריך לקחת את הטענה יש פה שולחן ולפרק אותה לחלקים קטנים. אפשר להתחיל בלמה אני חושב שיש פה שולחן? - אולי מפני שאני רואה אותו, מפני שאפשר לגעת בו, או מכל סיבה אחרת. על כל אחת ... אם גם כאן הוא לא מסכים, צריך לקחת עוד צעד אחורה ולבדוק על מה כן יש הסכמה, עד שמוצאים נקודה משותפת שממנה אפשר להתקדם. מדוע אנשים לא אוהבים לפרק רעיונות לחלקים? אליעד מסביר שרוב האנשים נמנעים מלפרק את הטענות שלהם לחלקים קטנים משום שזה חושף אותם. אם הטענה שלך נכונה באופן מוחלט וברור לך איך אתה יודע אותה, אז יהיה לך קל לפרק אותה לחלקים ולהסביר. אבל אם אינך בטוח בעצמך או אינך יודע איך אתה יודע את הטענה שלך, אתה תעדיף לא לפרק, כי אז אתה חושף את החולשה בטענה שלך. לדוגמה, אם הטענה שלך היא אני יודע שיש פה שולחן כי אני רואה אותו, אתה עלול לחשוש לשאול עוד שאלות כמו ... יותר מורכב, כך צריך לחלק אותו ליותר הקדמות, והיכולת להסביר רעיון תלויה בהבנה שלך איך הגעת אליו. רק מי שמבין לגמרי איך הוא יודע משהו, יוכל לפרק את זה ולהסביר את זה לאחרים. אם יש שלב שלא ברור לך, אתה לא תוכל להסביר אותו לאחרים. כיצד לנהוג כאשר אדם אומר לא הבנתי? כאשר מישהו אומר לך ... שמעת שאמרתי?, בלי פרשנויות. כך תוכל לגלות האם הוא לא הבין את המילים עצמן או שהוא לא הבין את הכוונה שלהן. אחרי שהבהרתם את זה, אפשר להמשיך לפרק את הרעיון לחלקים קטנים יותר. מה הקשר בין סיבתיות לטיפול בהפרעות נפשיות? אליעד כהן מוסיף שבמצבים של הפרעות נפשיות, כשנדמה שאין שום הסכמה אפילו על דברים בסיסיים, חייבים למצוא לפחות נקודת הסכמה אחת, אפילו קטנה מאוד. ברגע שמוצאים נקודה כזו, ניתן לפרק את חוסר ההסכמה בצורה שיטתית, ולמצוא בדיוק איפה הנקודה שהאדם אינו מסכים עליה. זיהוי מדויק של נקודה זו מאפשר להתחיל לתקן את התפיסות המוטעות ... יותר. לסיום, אליעד מדגיש שכדי להצליח בכל התהליך הזה, אדם צריך לתרגל באופן קבוע ניתוח סיבתיות עם עצמו - כך הוא יידע טוב יותר להסביר לאחרים ולפרק רעיונות בצורה ברורה ופשוטה. איך לגרום למישהו להסכים איתי? איך להסביר רעיון מורכב? מהי שיטת הפירוק לחלקים? למה אנשים לא מבינים אותי? איך ...
איך לפתור בעיות מורכבות? איך למצוא תשובות לשאלות מורכבות? איך לפתור בעיות קשות? איך לפרק לגורמים בעיה? מה זה פירוק לגורמים? איך למצוא את הנחות היסוד של השאלה? איך לפתור בעיות מסובכות? איך לפרק בעיה לגורמים?
איך לפתור בעיות מורכבות? איך למצוא תשובות לשאלות מורכבות? איך לפתור בעיות קשות? איך לפרק לגורמים בעיה? מה זה פירוק לגורמים? איך למצוא את הנחות היסוד של השאלה? איך לפתור בעיות מסובכות? איך לפרק בעיה לגורמים?
... לפתור בעיות מורכבות? איך למצוא תשובות לשאלות מורכבות? איך לפתור בעיות קשות? איך לפרק לגורמים בעיה? מה זה פירוק לגורמים? איך למצוא את הנחות היסוד של השאלה? איך לפתור בעיות מסובכות? איך לפרק בעיה לגורמים? איך לפתור בעיות מורכבות? איך למצוא תשובות לשאלות מורכבות? איך לפרק בעיה לגורמים? ההרצאה עוסקת בשאלות כיצד להתמודד עם בעיות מורכבות ולמצוא תשובות לשאלות קשות. אליעד כהן מציע גישה מסודרת לפתרון בעיות על ידי פירוקן לגורמים קטנים יותר, על מנת למצוא את התשובות המתאימות. התחלה עם רשימת שאלות ... בשאלות אחרות. כלומר, לפעמים נתחיל בשאלה אחת, ואז נבצע סדר בהמשך על ידי פירוק השאלות לגורמים. פירוק שאלה אחת לשאלות פשוטות יותר במקום להתמודד עם שאלה רחבה ומורכבת, כדאי לשאול האם ניתן לפרק אותה לשאלות פשוטות יותר. לדוגמה, אם יש שאלה מסובכת על הנחות יסוד ... ושיש תופעה שנקראת תוחלת חיים. שאלות רבות תלויות בהנחות יסוד שאותן חשוב להבהיר. האם ניתן לפרק שאלה מורכבת לגורמים? כאשר יש שאלה מורכבת, לא תמיד ניתן לפשט אותה. במקרים כאלה, השאלה ... להפוך בעיות מסובכות לפשוטות יותר ולמצוא פתרונות עקביים. פתרון בעיות מורכבות? פירוק בעיה לגורמים? הנחות יסוד של השאלה? הסדר החשיבתי בפתרון בעיות? איך להתמודד עם ...
מה זה אינטלקטואל? דוגמא לפירוק בעיה לגורמים, איך לנתח בעיה לגורמים? איך לפרק שאלה לתתי שאלות? איך להפוך שאלה מורכבת לשאלה פשוטה? איך לפרק לגורמים שאלה? איך למצוא תשובות לשאלות מורכבות? פתרון בעיות מסובכות
מה זה אינטלקטואל? דוגמא לפירוק בעיה לגורמים, איך לנתח בעיה לגורמים? איך לפרק שאלה לתתי שאלות? איך להפוך שאלה מורכבת לשאלה פשוטה? איך לפרק לגורמים שאלה? איך למצוא תשובות לשאלות מורכבות? פתרון בעיות מסובכות
... זה אינטלקטואל? דוגמא לפירוק בעיה לגורמים, איך לנתח בעיה לגורמים? איך לפרק שאלה לתתי שאלות? איך להפוך שאלה מורכבת לשאלה פשוטה? איך לפרק לגורמים שאלה? איך למצוא תשובות לשאלות מורכבות? פתרון בעיות מסובכות מה זה אינטלקטואל? במהלך ההרצאה, אליעד כהן מציג שאלה שנשאלת על ידי אדם שאינו מבין מהו אינטלקטואל ומסביר כיצד להתמודד עם שאלות מסוג זה. השאלה מה זה אינטלקטואל? היא לא פשוטה, כי לא מדובר רק בהגדרה בסיסית, אלא בשאלה שדורשת התעמקות ויכולת לפרק אותה לגורמים. אליעד מסביר שברגע שנשאלת שאלה כזו, צריך לשאול קודם כל: מה זה אינטלקט? מה המשמעות של המילה הזו? מהי הקשר בין אינטלקט לבין אינטלקטואל? החשיבות כאן היא להבין את המילים שבשאלה. אינטלקט הוא לא רק המובן הרגיל של שכל, אלא מושג שדורש הבנה עמוקה יותר, וצריך לפרק את השאלה כך שנוכל לנתח את כל הרכיבים שלה. איך לפרק בעיה לגורמים? אליעד מציין שלפני שניתן תשובה לשאלה מהו אינטלקטואל, חשוב לפתח את היכולת לפרק את הבעיה לגורמים . אם לא מבינים את המונח או את השאלה, השלב הראשון הוא לבדוק אם אפשר לפרק את המילה או את המושג לגורמים . לדוגמה, אם נשאלת השאלה מה זה אינטלקטואל?, לפני שניתן תשובה יש להבין את המילים המרכיבות את המילה אינטלקטואל - מה זה אינטלקט? מהו השורש של המילה? אילו מושגים ... הבנה טובה יותר. השלב המתקדם: פריצת דרך בעזרת הפירוק כחלק מההסבר, אליעד מציין את החשיבות של גישה מסודרת וברורה בשאלות ובבעיות מסובכות. אם לא נפרק את השאלה או הבעיה לגורמים, לא נוכל להגיע לפתרון אמיתי ומעמיק. הוא מבצע חזרה על עקרון הפירוק, ומדגיש שזהו כלי קריטי בהבנת מושגים והגדרת מושגים בצורה נכונה. במילים אחרות, אליעד מסביר שלפני ... בירור ובדיקה של הנחות יסוד לפני שניתן מענה מדויק. המטרה היא לא רק לקבל תשובה שטחית, אלא להבין את התהליכים שמובילים לפתרון בצורה מעמיקה ומסודרת. מהו אינטלקט? איך לפרק שאלה לגורמים? מהו אינטלקטואל? איך למצוא תשובות לשאלות מורכבות? פתרון בעיות מסובכות שיטות לפירוק בעיה לגורמים
ספרים מומלצים עבורך - ספרים על חידת LeetCode Solution - Block Placement Queries, פתרון ליטקוד, LeetCode Solution, לפתור שאלות ב LeetCode, מדעי המחשב, תכנות מחשבים, לעבוד בהייטק, ללמוד תכנות מחשבים, להיות מתכנת, ללמוד לתכנת, הכנה לראיון טכני, ראיון עבודה בהייטק, שאלות ליטקוד, פיתוח תוכנה, איך לכתוב קוד? ללמוד לכתוב קוד, חידות היגיון, ללמוד לחשוב, ללמוד לנתח דברים, ללמוד לפרק לגורמים, ללמוד לחלק לחלקים, ללמוד למצוא חוקיות, איך לחלק לחלקים? איך למצוא חוקיות? לנתח תהליכים
 👈1 ב 150  👈4 ב 400     ☎️ 050-3331-331    שליח עד אליך - בחינם!
הצלחה אהבה וחיים טובים - הספר על: לפתור שאלות ב leetcode, איך להיות מאושר ושמח? איך לשכנע אנשים ולקוחות? איך למצוא זוגיות? איך לשתול מחשבות? איך לחנך ילדים? איך לא להישחק בעבודה? איך להתמודד עם אובססיות והתמכרויות? איך למכור מוצר ללקוחות? איך להעריך את עצמך? איך לטפל בהתנגדויות מכירה? איך לפרש חלומות? איך להשיג ביטחון עצמי? איך לדעת אם מישהו מתאים לך? איך להאמין בעצמך? איך להתמודד עם דיכאון ותחושות רעות? איך להצליח בדיאטה ולשמור על המשקל? איך לקבל החלטות? איך לדעת איזה מקצוע מתאים לך? איך להתמודד עם גירושין? איך ליצור מוטיבציה ולהשיג מטרות? איך לעשות יותר כסף? איך להצליח בראיון עבודה? איך ליצור אהבה? איך לשנות תכונות אופי? איך לנהל את הזמן? איך להצליח בזוגיות? איך לחשוב בחשיבה חיובית? איך להעביר ביקורת בונה? איך להיגמל מהימורים? איך לשפר את הזיכרון? איך לגרום למישהו לאהוב אותך? איך לפתח חשיבה יצירתית? איך לפתח יכולות חשיבה ועוד...

שקט נפשי אמיתי - הספר על: לפתור שאלות ב leetcode, איך להתמודד עם תסמינים של חרדה? איך להשיג איזון נפשי? מועקות נפשיות וייאוש? איך להתמודד עם בדידות? איך להתמודד עם OCD / הפרעה טורדנית כפייתית / אובססיות / התנהגות כפייתית? איך להתמודד עם כל סוגי הפחדים והחרדות שיש? איך להתמודד עם התקפי חרדה ופאניקה? איך להתמודד עם טראומה ופוסט טראומה? איך להתמודד עם פחד קהל ופחד במה / פחד להתחיל עם בחורות / פחד להשתגע / פחד לאבד שליטה / חרדת נטישה / פחד מכישלון / פחד מוות / פחד ממחלות / פחד לקבל החלטה / פחד ממחויבות / פחד מבגידה / פחד מיסטי / פחד ממבחנים / חרדה כללית / פחד לא ידוע / פחד מפיטורים / פחד ממכירות / פחד מהצלחה / פחד לא הגיוני ועוד? איך להתמודד עם עצבות? איך להתמודד עם הפרעות קשב וריכוז? איך להתמודד עם רגשות אשם ושנאה עצמית? דיכאון? איך להתמודד עם ביישנות וחרדה חברתית? איך להתמודד עם לחץ? איך להתמודד עם אכזבות? איך לשכוח אקסים ולא להתגעגע? איך להתמודד עם אהבה אובססיבית? כעס ועצבים? איך להתמודד עם הזיות / דמיונות שווא / פרנויות / סכיזופרניה / הפרעת אישיות גבולית? איך להתמודד עם חרדות + פחדים של ילדים? איך להתמודד עם שמיעת קולות בראש? איך להתמודד עם בעיות ריכוז והפרעת קשב וריכוז? איך להתמודד עם חלומות מפחידים וסיוטים בשינה? איך להתמודד עם מאניה דיפרסיה ועם מצבי רוח משתנים? איך להתמודד עם הפרעות התנהגות אצל ילדים ועוד...

להיות אלוהים, 2 חלקים - הספר על: האם המציאות היא טובה או רעה? למה לא להתאבד? מה המשמעות של החיים? איך להנות בחיים? איך להשיג שלמות ואושר מוחלט? למה יש רע וסבל בעולם? האם באמת הכל לטובה? איך להיות מאושר? מהי תכלית ומשמעות החיים? איך נוצר העולם? בשביל מה לחיות? האם יש חיים מחוץ לכדור הארץ ויקומים מקבילים? מה יש מעבר לשכל וללוגיקה? האם יש הבדל בין חלום למציאות? אולי אנחנו במטריקס? האם יש נשמה וחיים אחרי המוות? איך נוצר העולם? מי ברא את אלוהים? למה העולם קיים? האם יש משמעות לחיים? האם יש אמת מוחלטת? האם יש או אין אלוהים? למה חוקי הפיזיקה כפי שהם? למה יש רע בעולם? האם הכל אפשרי? האם יש בחירה חופשית? האם אפשר לדעת הכל? איך נוצרים רצונות / מחשבות / רגשות? האם לדומם יש תודעה? איך להיות הכי חכם בעולם? מה יש מעבר לזמן ולמקום ועוד...
רק כאן באתר! ✨ להנאתך, 10,000+ שעות של תכנים בלעדיים! ✨ מאת אליעד כהן!
לפניך חלק מהנושאים שבאתר... מה מעניין אותך?

חפש:   מיין:

האתר www.EIP.co.il נותן לך תכנים בנושא הכוונה אישית, אימון אישי להפרעות קשב וריכוז, מאמן מנטלי בתחום לפתור שאלות ב leetcode - ללא הגבלה! לקביעת פגישה אישית / ייעוץ טלפוני אישי / הזמנת הספרים - צור/י עכשיו קשר: 050-3331-331
© כל הזכויות שמורות לאתר www.EIP.co.il בלבד!
מומלץ ביותר, לצטט תוכן מהאתר במקומות שונים,
ובתנאי שתמיד יצורף קישור לכתובת שבה מופיע התוכן המקורי ולאתר.
האתר פותח על ידי אליעד כהן
דף זה הופיע ב 0.3438 שניות - עכשיו 23_05_2025 השעה 07:24:32 - wesi1