Hello Programmers/Coders, Today we are going to share solutions of Programming problems of HackerRank of Programming Language C++ . At Each Problem with Successful submission with all Test Cases Passed, you will get an score or marks. And after solving maximum problems, you will be getting stars. This will highlight you profile to the recruiters.
In this post, you will find the solution for Input and Abstract Classes – Polymorphism in C++-HackerRank Problem. We are providing the correct and tested solutions of coding problems present on HackerRank. If you are not able to solve any problem, then you can take help from our Blog/website.
Use “Ctrl+F” To Find Any Questions Answer. & For Mobile User, You Just Need To Click On Three dots In Your Browser & You Will Get A “Find” Option There. Use These Option to Get Any Random Questions Answer.
Introduction To C++
C++ is a general-purpose programming language that was developed as an enhancement of the C language to include object-oriented paradigm. It is an imperative and a compiled language.
C++ is a middle-level language rendering it the advantage of programming low-level (drivers, kernels) and even higher-level applications (games, GUI, desktop apps etc.). The basic syntax and code structure of both C and C++ are the same.
C++ programming language was developed in 1980 by Bjarne Stroustrup at bell laboratories of AT&T (American Telephone & Telegraph), located in U.S.A. Bjarne Stroustrup is known as the founder of C++ language.
Abstract Classes – Polymorphism in C++ – Hacker Rank Solution
Problem
Abstract base classes in C++ can only be used as base classes. Thus, they are allowed to have virtual member functions without definitions.
A cache is a component that stores data so future requests for that data can be served faster. The data stored in a cache might be the results of an earlier computation, or the duplicates of data stored elsewhere. A cache hit occurs when the requested data can be found in a cache, while a cache miss occurs when it cannot. Cache hits are served by reading data from the cache which is faster than recomputing a result or reading from a slower data store. Thus, the more requests that can be served from the cache, the faster the system performs.
One of the popular cache replacement policies is: “least recently used” (LRU). It discards the least recently used items first.
For example, if a cache with a capacity to store 5 keys has the following state(arranged from most recently used key to least recently used key) –
5 3 2 1 4
Now, If the next key comes as 1(which is a cache hit), then the cache state in the same order will be –
1 5 3 2 4
Now, If the next key comes as 6(which is a cache miss), then the cache state in the same order will be –
6 1 5 3 2
You can observe that 4 has been discarded because it was the least recently used key and since the capacity of cache is 5, it could not be retained in the cache any longer.
Given an abstract base class Cache with member variables and functions:
mp – Map the key to the node in the linked list
cp – Capacity
tail – Double linked list tail pointer
head – Double linked list head pointer
set() – Set/insert the value of the key, if present, otherwise add the key as the most recently used key. If the cache has reached its capacity, it should replace the least recently used key with a new key.
get() – Get the value (will always be positive) of the key if the key exists in the cache, otherwise return -1.
You have to write a class LRUCache which extends the class Cache and uses the member functions and variables to implement an LRU cache.
Input Format :
First line of input will contain the N number of lines containing get or set commands followed by the capacity M of the cache.
The following N lines can either contain get or set commands.
An input line starting with get will be followed by a key to be found in the cache. An input line starting with set will be followed by the key and value respectively to be inserted/replaced in the cache.
Constraints :
1 <= N <= 500000
1 <= M <= 1000
1 <= key <= 20
1 <= value <= 2000
Output Format :
The code provided in the editor will use your derived class LRUCache to output the value whenever a get command is encountered.
Sample Input :
3 1 set 1 2 get 1 get 2
Sample Output :
2 -1
Explanation :
Since, the capacity of the cache is 1, the first set results in setting up the key 1 with it’s value 2. The first get results in a cache hit of key 1, so 2 is printed as the value for the first get. The second get is a cache miss, so -1 is printed.
Abstract Classes – Polymorphism in C++ – Hacker Rank Solution
#include <iostream> #include <vector> #include <map> #include <string> #include <algorithm> #include <set> #include <cassert> using namespace std; struct Node { Node* next; Node* prev; int value; int key; Node(Node* p, Node* n, int k, int val):prev(p),next(n),key(k),value(val){}; Node(int k, int val):prev(NULL),next(NULL),key(k),value(val){}; }; class Cache { protected: map<int,Node*> mp; //map the key to the node in the linked list int cp; //capacity Node* tail; // double linked list tail pointer Node* head; // double linked list head pointer virtual void set(int, int) = 0; //set function virtual int get(int) = 0; //get function }; // Abstract Classes - Polymorphism in C++ - Hacker Rank Solution start class LRUCache: public Cache { public: LRUCache(int c) { cp = c; } void set(int k, int v) { Node* N; if ( mp.empty() ) { N = new Node(k,v); tail = head = N; mp[k] = N; return; } auto it = mp.find(k); if ( it != mp.end() ) { it->second->value = v; if ( head == it->second ) { return; } it->second->prev->next = it->second->next; if ( tail == it->second ) { tail = tail->prev; } else { it->second->next->prev = it->second->prev; } it->second->next = head; it->second->prev = nullptr; head->prev = it->second; head = it->second; } else { N = new Node(head->prev, head, k, v); head->prev = N; head = N; mp[k] = N; if ( mp.size() > cp ) { tail = tail->prev; mp.erase(tail->next->key); delete tail->next; tail->next = nullptr; } } } int get(int k) { auto it = mp.find(k); if ( it != mp.end() ) { return it->second->value; } return -1; } }; // Abstract Classes - Polymorphism in C++ - Hacker Rank Solution End int main() { int n, capacity,i; cin >> n >> capacity; LRUCache l(capacity); for(i=0;i<n;i++) { string command; cin >> command; if(command == "get") { int key; cin >> key; cout << l.get(key) << endl; } else if(command == "set") { int key, value; cin >> key >> value; l.set(key,value); } } return 0; }
Good info. Lucky me I reach on your website by accident, I bookmarked it.
At this time it appears like Expression Engine is the best blogging platform available right now. (from what I’ve read) Is that what you are using on your blog?
you’re really a good webmaster. The web site loading speed is incredible. It seems that you’re doing any unique trick. Moreover, The contents are masterpiece. you have done a great job on this topic!
Thanks for another great post. Where else could anybody get that type of info in such a perfect way of writing? I’ve a presentation next week, and I’m on the look for such info.
Lovely website! I am loving it!! Will come back again. I am taking your feeds also
I really treasure your work, Great post.
I like this site so much, bookmarked.
cialis coupon cialis in usa buy generic ed pills for sale
certainly like your website however you need to take a look at the spelling on several of your posts. Many of them are rife with spelling problems and I find it very bothersome to tell the reality nevertheless I’ll definitely come back again.
buy duricef cheap propecia 5mg ca cost finasteride 5mg
buy generic diflucan for sale buy acillin tablets purchase ciprofloxacin sale
how to get flagyl without a prescription sulfamethoxazole tablet buy cephalexin 250mg online cheap
buy cleocin 150mg online order erythromycin 500mg online cheap cheap ed pills
nolvadex 10mg usa cost cefuroxime 250mg cefuroxime cost
careprost over the counter oral trazodone 100mg buy trazodone generic
sildenafil 100mg cost buy sildalis pills sildenafil 100mg pills for sale
accutane 20mg tablet azithromycin 250mg oral buy azithromycin medication
azithromycin price omnacortil for sale online cheap neurontin
lasix 40mg cheap purchase monodox pills buy albuterol inhaler
levitra 10mg brand buy hydroxychloroquine 200mg online cheap brand hydroxychloroquine
buy altace 5mg for sale cost glimepiride 4mg arcoxia over the counter
buy mesalamine pills buy mesalamine generic irbesartan 150mg pills
olmesartan ca benicar sale divalproex over the counter
temovate without prescription buy temovate cream cordarone 200mg canada
acetazolamide 250 mg without prescription how to get acetazolamide without a prescription azathioprine 50mg tablet
order digoxin 250mg pills purchase digoxin for sale molnunat 200 mg cost
order naproxen purchase omnicef generic lansoprazole over the counter
coreg us chloroquine 250mg sale aralen canada
proventil 100 mcg without prescription proventil cost order pyridium 200 mg online
olumiant 4mg pill buy glycomet 1000mg without prescription order atorvastatin 80mg online
order nifedipine generic perindopril 8mg tablet fexofenadine 120mg over the counter