C Program to Calculate Generic Root of a Number using Mathematical Formula

Lets write a C program to calculate Generic Root of a Number using Mathematical Formula.

Related Read:
C Program to Find Generic Root of a Number
C Program to Calculate Generic Root of a Number using Ternary Operator

For Example: If user input number is 589, then we add all the individual digits of the number i.e., 5 + 8 + 9 = 22. We get 22. Now we add individual digits of number 22 i.e., 2 + 2 = 4. So Generic Root of number 589 is 4.

Generic Root: We keep adding individual digits of a number until we get single digit output.

Formula To Calculate Generic Root

generic_root = 1 + ( (number-1)%9 );

Source Code: C Program to Calculate Generic Root of a Number using Mathematical Formula

  1.    
  2. #include < stdio.h >  
  3.   
  4. int main()  
  5. {  
  6.     int num, res;  
  7.   
  8.     printf("Enter a number above 10\n");  
  9.     scanf("%d", &num);  
  10.   
  11.     printf("Generic Root of %d is %d\n", num, 1+((num-1)%9) );  
  12.   
  13.     return 0;  
  14. }  

Output 1:
Enter a number above 10
586
Generic Root of 586 is 1

Output 2:
Enter a number above 10
8
Generic Root of 8 is 8

Output 3:
Enter a number
589
Generic Root of 589 is 4

C Program to Calculate Generic Root of a Number using Mathematical Formula


[youtube https://www.youtube.com/watch?v=pI0tOD_CrSs]

YouTube Link: https://www.youtube.com/watch?v=pI0tOD_CrSs [Watch the Video In Full Screen.]


For list of all c programming interviews / viva question and answers visit: C Programming Interview / Viva Q&A List

For full C programming language free video tutorial list visit:C Programming: Beginner To Advance To Expert

Project Structure: Ionic 2

Before we move forward with coding, it’s important to know some of the files and folders present inside our ionic 2 project. Since you’re a beginner you might find this video to be confusing and fast paced. But let me assure you, this won’t affect your learning of Ionic 2. How much ever time you spend in understanding the anatomy of an ionic 2 cordova project, you won’t understand it properly until we start coding and utilizing these files and folders for our application needs.

I would advice you to take down whatever you understand in this video in a note-book and keep it for your future reference. It would be handy soon.

anatomy of ionic2 cordova project

hooks: this is not for beginners, so will skip that for now.
node_modules: This is where core libraries like angular2, ionic2, array manipulation, regEx etc are present. We import these libraries in our ionic 2 project and utilize their services.
plugins: Here Ionic 2 project specific cordova plugins are stored. There are many plugins which ionic-native provides which we can make use of for our application needs. For example: If you need to use your devices camera functionality, there is a cordova plugin for that which you can use in your ionic 2 project.
resources: Here we store icon and splashscreen files of our app.
src: is where we can find raw, uncompiled code. Inside src we have our page components(src/pages), application root components(src/app), static files(src/assets) etc, which gets transpiled, compiled, minified and stored inside www folder during the build process. If you edit any file inside www folder, it’ll simply be overwritten during the build process.

Anatomy of an Ionic 2 Project


[youtube https://www.youtube.com/watch?v=JpB3FafevH4]

YouTube Link: https://www.youtube.com/watch?v=JpB3FafevH4 [Watch the Video In Full Screen.]


src/assets: We store static resource files in this folder. Example: Image files which we use for our project.

src/pages: For every page you create you’ll add another folder in this directory. For example, if you want to create a login page, you’ll need to create a folder called login(or any other unique name) and then store the login template, login class definition file and login style definition file inside that folder. Ionic CLI can be used to automate this process and I’ll show you how to do it in upcoming video tutorials.

src/theme: This folder has style definition which is applicable for the entire application. We can simply change the value of some variables and customize the look and feel of our application. This will also be explained in a separate video tutorial in coming days.

src/app: This folder is where the ‘root components’ of our application are located. main.dev.ts and main.prod.ts files are responsible for the bootstrapping process of the application. main.dev.ts is active in development mode and main.prod.ts should be used in production environment.

src/app/app.module.ts is the entry point for the app.

  1. import { NgModule } from '@angular/core';  
  2. import { IonicApp, IonicModule } from 'ionic-angular';  
  3. import { MyApp } from './app.component';  
  4. import { AboutPage } from '../pages/about/about';  
  5. import { ContactPage } from '../pages/contact/contact';  
  6. import { HomePage } from '../pages/home/home';  
  7. import { TabsPage } from '../pages/tabs/tabs';  
  8.   
  9. @NgModule({  
  10.   declarations: [  
  11.     MyApp,  
  12.     AboutPage,  
  13.     ContactPage,  
  14.     HomePage,  
  15.     TabsPage  
  16.   ],  
  17.   imports: [  
  18.     IonicModule.forRoot(MyApp)  
  19.   ],  
  20.   bootstrap: [IonicApp],  
  21.   entryComponents: [  
  22.     MyApp,  
  23.     AboutPage,  
  24.     ContactPage,  
  25.     HomePage,  
  26.     TabsPage  
  27.   ],  
  28.   providers: []  
  29. })  
  30. export class AppModule {}  

This essentially controls the work flow of rest of the application.

Using NgModule of angular core library we manage the modules in our ionic 2 applications. All the components and data services we create must be imported in this file and its class name must be specified inside the declarations and entryComponents section. If we have any data service providers we must specify it inside providers block. This file also points to the first component of our Ionic 2 application i.e., MyApp class of src/app/app.component.ts

src/app/app.component.ts is the first component of Ionic 2 application

  1. import { Component } from '@angular/core';  
  2. import { Platform } from 'ionic-angular';  
  3. import { StatusBar, Splashscreen } from 'ionic-native';  
  4.   
  5. import { TabsPage } from '../pages/tabs/tabs';  
  6.   
  7.   
  8. @Component({  
  9.   template: `<ion-nav [root]="rootPage"></ion-nav>`  
  10. })  
  11. export class MyApp {  
  12.   rootPage = TabsPage;  
  13.   
  14.   constructor(platform: Platform) {  
  15.     platform.ready().then(() => {  
  16.       // Okay, so the platform is ready and our plugins are available.  
  17.       // Here you can do any higher level native things you might need.  
  18.       StatusBar.styleDefault();  
  19.       Splashscreen.hide();  
  20.     });  
  21.   }  
  22. }  

This is the first component which gets loaded in our application. It’s simply an empty shell for other components to load into.

One important thing to note here is the rootPage. Since this is a project which uses tabs template, it has automatically assigned the rootPage to the TabsPage present in our src/pages/tabs/tabs.ts page.

src/pages/tabs/tabs.ts component

  1. import { Component } from '@angular/core';  
  2.   
  3. import { HomePage } from '../home/home';  
  4. import { AboutPage } from '../about/about';  
  5. import { ContactPage } from '../contact/contact';  
  6.   
  7. @Component({  
  8.   templateUrl: 'tabs.html'  
  9. })  
  10. export class TabsPage {  
  11.   // this tells the tabs component which Pages  
  12.   // should be each tab's root Page  
  13.   tab1Root: any = HomePage;  
  14.   tab2Root: any = AboutPage;  
  15.   tab3Root: any = ContactPage;  
  16.   
  17.   constructor() {  
  18.   
  19.   }  
  20. }  

Here we are importing 3 pages HomePage, AboutPage and ContactPage and then assigning it to each tab.

src/pages/tabs/tabs.html template file

  1. <ion-tabs>  
  2.   <ion-tab [root]="tab1Root" tabTitle="Home" tabIcon="home"></ion-tab>  
  3.   <ion-tab [root]="tab2Root" tabTitle="About" tabIcon="information-circle"></ion-tab>  
  4.   <ion-tab [root]="tab3Root" tabTitle="Contact" tabIcon="contacts"></ion-tab>  
  5. </ion-tabs>  

Which is then assigned as root pages on each tab. This is to maintain the sanity of navigation history. We’ll discuss about navigation in Ionic 2 in a separate video shortly.

src/index.html

  1. <!DOCTYPE html>  
  2. <html lang="en" dir="ltr">  
  3. <head>  
  4.   <meta charset="UTF-8"/>  
  5.   <title>Ionic App</title>  
  6.   <meta name="viewport" content="width=device-width, initial-scale=1.0,   
  7.         minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"/>  
  8.   <meta name="format-detection" content="telephone=no"/>  
  9.   <meta name="msapplication-tap-highlight" content="no"/>  
  10.    
  11.   <link rel="icon" type="image/x-icon" href="assets/icon/favicon.ico"/>  
  12.   <link rel="manifest" href="manifest.json"/>  
  13.   <meta name="theme-color" content="#4e8ef7"/>  
  14.    
  15.   <!-- cordova.js required for cordova apps -->  
  16.   <script src="cordova.js"></script>  
  17.    
  18.   <!-- un-comment this code to enable service worker  
  19.   <script>  
  20.     if ('serviceWorker' in navigator) {  
  21.       navigator.serviceWorker.register('service-worker.js')  
  22.         .then(() => console.log('service worker installed'))  
  23.         .catch(err => console.log('Error', err));  
  24.     }  
  25.   -->  
  26.    
  27.   <link href="build/main.css" rel="stylesheet"/>  
  28.    
  29. </head>  
  30. <body>  
  31.    
  32.   <!-- Ionic's root component and where the app will load -->  
  33.   <ion -app></ion>  
  34.    
  35.   <!-- The polyfills js is generated during the build process -->  
  36.   <script src="build/polyfills.js"></script>  
  37.    
  38.   <!-- The bundle js is generated during the build process -->  
  39.   <script src="build/main.js"></script>  
  40.    
  41. </body>  
  42. </html>  

This file has some minimal configurations and links to some JavaScript library files. Ionic 2 application looks for ion-app tag present inside the body of index.html to kick-start the visuals of the project.

config.xml (located at the root of the project)

  1. <?xml version="1.0" encoding="UTF-8" standalone="yes"?>  
  2. <widget id="com.technotip.radio" version="0.0.1"   
  3.         xmlns="http://www.w3.org/ns/widgets"   
  4.         xmlns:cdv="http://cordova.apache.org/ns/1.0">  
  5.   <name>Radio</name>  
  6.   <description>Internet radio streaming live ..</description>  
  7.   <author email="my@mail.com" href="https://technotip.com/">SATISH</author>  
  8.  .  
  9.  .  
  10.  .  
  11.  .  
  12. </widget>  

Using this file we can configure the display mode and other such things of the device for our application. We can also set the app name, description. author email id, name and the URL. We can set the id of the application which’ll be shown in the URL of the playstore once your app has been uploaded to the playstore. We have a radio application in the playstore which has an id com.technotip.radio You can visit our Radio Application and check the URL.

package.json (located at the root of our application)
This file has the list of our dependencies and plugins our application is using. It gets updated automatically when we install new plugins.

Important: Keep in mind that, whenever you are using any page component or data services in any of your project files, make sure to import it first. Also make sure to register its existence by importing it in src/app/app.module.ts file and listing it in specific sections which it belongs to.