Tuesday, November 1, 2022

Problem solved - Word

Hi. As I practice on various coding platforms, I keep on sharing my solutions as a blog post for me to refer back in future and also broadly for anyone searching for the same.

With this, let's begin with today's problem :- 

Problem Name - Word

Problem Code - 59-A

Problem Link - https://codeforces.com/problemset/problem/59/A

How I solved it :-

Language used : C++

#include <bits/stdc++.h>
using namespace std;
typedef long long int ll;
typedef vector<int> vi;
typedef vector<vi> vvi;
#define MOD 1000000007
#define endl '\n'
#define FAST                          \
    ios_base::sync_with_stdio(false); \
    cin.tie(0);                       \
    cout.tie(0);
#define T     \
    ll t;     \
    cin >> t; \
    while (t--)
int main(void)
{
    FAST;
    // test cases :-
    string s;
    cin >> s;
    int c1 = 0, c2 = 0;
    for (int i = 0; i < s.size(); i++)
    {
        if (s[i] >= 'a' && s[i] <= 'z')
            c2++;
        else
            c1++;
    }
    if (c1 > c2)
        transform(s.begin(), s.end(), s.begin(), ::toupper);
    else
        transform(s.begin(), s.end(), s.begin(), ::tolower);
    cout << s;
    return 0;
}

Highlights : Learnt about the 'transform' function in C++ : https://www.educative.io/answers/what-is-the-transform-function-in-cpp


Gaussian Blur?


    After hearing of this from an article, I was searching for this technique and this is what I found out :-


    [ PS: I keep on sharing my findings as a blog post for me to refer back in future and also broadly             for  anyone searching for the same. ]







Monday, October 31, 2022

Low Pass Filter?

 Got to know about a new term today from Google, Wikipedia :-



Problem solved - XOR Equality

Hi. As I practice on various coding platforms, I keep on sharing my solutions as a blog post for me to refer back in future and also broadly for anyone searching for the same.

With this, let us begin with today's problem :- 

Problem Name - XOR Equality

Problem Code - XOREQUAL

Problem Link - https://www.codechef.com/submit/XOREQUAL

How I solved it :-

Language used : C++

#include<iostream>
using namespace std;

#define m (int)(1e9+7)

int poww(int base, int expo){
    if(!expo) return 1;
    if(expo==1) return base%m;
    if(expo&1) return (1LL*(base%m)*(poww(base, expo-1)%m))%m;
    return poww((1LL*(base%m)*(base%m))%m, expo/2)%m;
}

void solve(void){
    int n;
    cin>>n;
    cout<<poww(2, n-1)%m<<'\n';
    return;
}

int main(void) {
	// your code goes here
	int t;
	cin>>t;
	while(t--) solve();
	return 0;
}

Monday, October 18, 2021

HANDS ON JAVA(OOP - based uses) (Part-IV)

            Practice JAVA like Never Before!

                                                                                                     courtesy: Google Images

Day 4 🔥

Objective

Learning to implement menu-driven programs, overloading methods and constructors:-

1. Design a class to represent a Bank Account. Include the following things:

Fields

• Name of the depositor

• Address of the depositor

• Account number

• Balance amount in the account

Methods

• To assign initial values

• To deposit an amount

• To withdraw an amount after checking balance

• To display the name, address, and balance of a customer

From the main() method create an object and call these methods.

  • Program

import java.util.Scanner;
class BankAcc{
String name, address;
long acc_no;
double balance;
BankAcc(String p, String q, long r, double s){
name = p;
address = q;
acc_no = r;
balance = s;
}
void deposit(double x){
System.out.println("Pre-existing Balance = "+balance);
balance += x;
System.out.println("Amount Deposited = "+x);
System.out.println("New Balance = "+balance);
}
void withdraw(double x){
System.out.println("Pre-existing Balance = "+balance);
balance -= x;
System.out.println("Amount Withdrawn = "+x);
System.out.println("New Balance = "+balance);
}
void display(){
System.out.println("Your(Account Holder) name is "+name+". \nYour"+
"account number is "+acc_no+". \nYour address is "+address+
". \nYour present balance = "+balance);
}
}//end class

class Main{
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
System.out.println("Enter your name:- ");
String name = sc.nextLine();
System.out.println("Enter your address:- ");
String add = sc.nextLine();
System.out.println("Enter your account number:- ");
long num = sc.nextLong();
System.out.println("Enter your initial balance:- ");
double bal = sc.nextDouble();
//creating and initializing an instance of class: BanAcc :-
BankAcc ob = new BankAcc(name, add, num, bal);
//MENU:-
System.out.println("OPTIONS MENU:\nEnter \'1\' to deposit money\n"+
"\'2\' to withdraw money\n\'3\' to see account info and \n\'-1\'"+
" to EXIT");
//running infinitely until user wants to break:-
int n, flag=1;
double temp;
while(flag==1){
System.out.println("\nEnter Your Choice:- ");
n = sc.nextInt();
switch(n){
case 1:
System.out.println("Enter the deposit amount:- ");
temp = sc.nextDouble();
ob.deposit(temp);
break;
case 2:
System.out.println("Enter the withdraw amount:- ");
temp = sc.nextDouble();
ob.withdraw(temp);
break;
case 3:
ob.display();
break;
case 4:
System.out.println("Thank You ^_^");
flag=0;
break;
default:
System.out.println("Invalid Choice! \nPlease try again.");
}//end switch case
}//end while
}//end main()
}//end class
  • Output:

       

---------------------------------------------------

2. Create a class and determine if method overloading holds good for the return type of methods or not.

  • Program:

Observation: Method overloading does not work if two methods are different only in terms of their return type.

Reason: when it’s called, it creates confusion on which function is being called since the no. of parameters and their data types are identical.

This is an example:-

class Operate{
int add(int p, int q){
return p+q;
}
double add(int p, int q){
return p+q;
}
}//end class

class Main{
public static void main(String[] args){
Operate obj = new Operate();
int n1 = obj.add(2, 3);
double n2 = obj.add(2, 7);
System.out.println("1st sum = "+n1+" and 2nd sum = "+n2);
}
}

            Error:- 

Solution: For method overloading to hold good,

having only different return types will not help.  

We need either:-

i> different data types of parameters:-

class Operate{
int add(int p, int q){
return p+q;
}
double add(double p, double q){
return p+q;
}
}//end class
class Main{
public static void main(String[] args){
Operate obj = new Operate();
int n1 = obj.add(2, 3);
double n2 = obj.add(100, 7.9);
System.out.println("1st sum = "+n1+" and 2nd sum = "+n2); 
        }
}
  • Output:


ii> different no. of parameters:-
class Operate{
int add(int p, int q){
return p+q;
}
double add(int p, int q, int r){
return p+q+r;
}
}//end class

class Main{
public static void main(String[] args){
Operate obj = new Operate();
int n1 = obj.add(2, 3);
double n2 = obj.add(100, 7, 250);
System.out.println("1st sum = "+n1+" and 2nd sum = "+n2);
}
}
  • Output:

---------------------------------------------------


3. Overload the constructors for classes Cuboid and Rectangle of a rectangular figure and display its area and volume. Rectangle is the superclass and Cuboid is the subclass.

  • Program:

import java.util.Scanner;
//Superclass:-
class Rectangle{
double len, breadth;
Rectangle(double l, double b){
this.len = l;
this.breadth = b;
}
double area(){
return len*breadth;
}
}
//Sub-class:-
class Cuboid extends Rectangle{
double height;
Cuboid(double l, double b, double h){
super(l, b);//parent class constructor call from child class
this.height = h;
}
double vol(){
return area()*height;
}
}
class Main{
public static void main(String[] args){
Scanner sc=new Scanner(System.in);
double l, b, h;
System.out.println("Enter length: ");
l = sc.nextDouble();
System.out.println("Enter breadth: ");
b = sc.nextDouble();
System.out.println("Enter height: ");
h = sc.nextDouble();
Cuboid obj = new Cuboid(l, b, h);
System.out.println("Area of Rectangle: "+obj.area());
System.out.println("Volume of Cuboid: "+obj.vol());
}
}
  • Output:


--------------------------------------------------

<---------- End of Part - IV ---------->😋


You may like these:

HANDS ON JAVA(OOP - based uses) (Part-I)

     Practice JAVA like Never Before!                                                                                                     ...