• Skip to primary navigation
  • Skip to content
  • Skip to primary sidebar
  • Skip to secondary sidebar

GoHired

Interview Questions asked in Google, Microsoft, Amazon

Join WeekEnd Online Batch from 4-April-2020 on How to Crack Coding Interview in Just 10 Weeks : Fees just 20,000 INR

  • Home
  • Best Java Books
  • Algorithm
  • Internship
  • Certificates
  • About Us
  • Contact Us
  • Privacy Policy
  • Array
  • Stack
  • Queue
  • LinkedList
  • DP
  • Strings
  • Tree
  • Mathametical
  • Puzzles
  • Graph

Given a string, find the first character which is non-repetitive

April 13, 2014 by Dhaval Dave

Given a string, find the first character which is non -repetitive i.e that character must not be present anywhere else in the string.

With two different solutions.

Eg : Input : teeterson      
     Output : r, as it is the first element which 
                        is non repetitive.

Solution 1 :

1) Scan the string from left to right and construct the count array.
2) Again, scan the string from left to right and check for count of 
each character, if you find an element who's count is 1, return it.

Time Complexity : O(2N)= O(N)
Space Complexity : O(N)

Solution 2 :

To reduce Time for searching , we can use Hashmap.
Benefit from previous solution:
to get count for 2,3 etc we can easily use this function with little modification
To search for count 1, no need to iterate array again.

map < int , character > m;
map < int , character > : iterator it;
void *getNonRepChar(char *str)
{
    int *count = (int *)calloc(sizeof(int), NO_OF_CHARS);
    int i;
    for (i = 0; *(str+i);  i++){
       count[*(str+i)]++;
       m.insert(make_pair(count,*(str+i)));
    }//for ended
  return count;
}//function ended

 it.find(1);
 if(it != end() ){
   // element found
   character op = it->second ; 
   printd (" %c has count %d" ,op,1); 
  }
 else  
 printf ("Not found Such element");

Time Complexity : O(N)
Space Complexity : O(N)

-IF YOU LIKE OUR EFFORT, PLEASE LIKE AND SHARE OUR FB-PAGE AND SITE

Similar Articles

Filed Under: Hacker Earth Questions, Interview Questions, problem Tagged With: string

Reader Interactions

Primary Sidebar

Join WeekEnd Online/Offline Batch from 4-April-2020 on How to Crack Coding Interview in Just 10 Weeks : Fees just 20,000 INR

Join WeekEnd Online/Offline Batch from 4-April-2020

WhatsApp us

Secondary Sidebar

Custom Search

  • How I cracked AMAZON
  • LeetCode
  • Adobe
  • Amazon
  • Facebook
  • Microsoft
  • Hacker Earth
  • CSE Interview

Top Rated Questions

Wrong Directions given find minimum moves so that he can reach to the destination

Print vertical sum of all the axis in the given binary tree

Amazon Interview On-Campus For Internship – 1

Search element in a matrix with all rows and columns in sorted order

Number of Islands BFS/DFS

Stickler thief

Spanning Tree

Maximum size of square sub matrix with all 1’s in a binary matrix

Count Possible Decodings of a given Digit Sequence

Convert number to words java

Python Array String

Get Minimum element in O(1) from input numbers or Stack

Memory Efficient LinkedList

Reversal of LinkedList

Convert Decimal to Roman numbers / Romanizer HackerEarth Code

Difference between a LinkedList and a Binary Search Tree BST

Word Break Problem

Right view of Binary tree

Binary Tree in Java

Sort Stack in place

BFS (Breath First Search)

Puzzle : 100 doors in a row Visit and Toggle the door. What state the door will be after nth pass ?

Reliance Jio Software Developer Interview Experience

Top 10 Interviews Techniqes for Campus Interview in IIT NIT BITS for MTech

Daughter’s Age VeryGood Puzzle

Find the number ABCD such that when multipled by 4 gives DCBA.

Best Java Book | Top Java Programming Book for Beginners

Singly linked list

Minimum insertions to form a palindrome

strtok()

Copyright © 2026 · Genesis Framework · WordPress · Log in