387. First Unique Character in a String
leetcode easy
#array#csharp#easy#leetcode#string
Task
Дана строка s, найдите первый неповторяющийся символ в ней и верните его индекс. Если такого символа не существует, верните -1.
Пример:
Input: s = "leetcode"
Output: 0
C# solution
matched/originalusing System;
using System.Collections.Generic;
public class Solution {
private int[] original;
private int[] array;
private Random rand = new Random();
public Solution(int[] nums) {
array = (int[])nums.Clone();
original = (int[])nums.Clone();
}
public int[] Reset() {
array = (int[])original.Clone();
return original;
}
public int[] Shuffle() {
for (int i = 0; i < array.Length; i++) {
int randIndex = rand.Next(i, array.Length);
int temp = array[i];
array[i] = array[randIndex];
array[randIndex] = temp;
}
return array;
}
}C++ solution
auto-draft, review before submit#include <bits/stdc++.h>
using namespace std;
// Auto-generated C++ draft from the C# solution. Review containers, LINQ and helper types before submit.
class Solution {
public:
private vector<int>& original;
private vector<int>& array;
private Random rand = new Random();
public Solution(vector<int>& nums) {
array = (int[])nums.Clone();
original = (int[])nums.Clone();
}
public vector<int>& Reset() {
array = (int[])original.Clone();
return original;
}
public vector<int>& Shuffle() {
for (int i = 0; i < array.size(); i++) {
int randIndex = rand.Next(i, array.size());
int temp = array[i];
array[i] = array[randIndex];
array[randIndex] = temp;
}
return array;
}
}Java solution
matched/originalimport java.util.Random;
public class Solution {
private int[] original;
private int[] array;
private Random rand = new Random();
public Solution(int[] nums) {
array = nums.clone();
original = nums.clone();
}
public int[] reset() {
array = original.clone();
return original;
}
public int[] shuffle() {
for (int i = 0; i < array.length; i++) {
int randIndex = rand.nextInt(array.length - i) + i;
int temp = array[i];
array[i] = array[randIndex];
array[randIndex] = temp;
}
return array;
}
}JavaScript solution
matched/originalclass Solution {
constructor(nums) {
this.original = [...nums];
this.array = [...nums];
}
reset() {
this.array = [...this.original];
return this.array;
}
shuffle() {
for (let i = 0; i < this.array.length; i++) {
const randIndex = Math.floor(Math.random() * (this.array.length - i)) + i;
[this.array[i], this.array[randIndex]] = [this.array[randIndex], this.array[i]];
}
return this.array;
}
}Python solution
matched/originalimport random
class Solution:
def __init__(self, nums: list[int]):
self.original = nums[:]
self.array = nums[:]
def reset(self) -> list[int]:
self.array = self.original[:]
return self.original
def shuffle(self) -> list[int]:
n = len(self.array)
for i in range(n):
rand_index = random.randint(i, n - 1)
self.array[i], self.array[rand_index] = self.array[rand_index], self.array[i]
return self.arrayGo solution
matched/originalpackage main
import (
"math/rand"
"time"
)
type Solution struct {
original []int
array []int
}
func Constructor(nums []int) Solution {
original := make([]int, len(nums))
copy(original, nums)
return Solution{
original: original,
array: append([]int(nil), nums...),
}
}
func (this *Solution) Reset() []int {
this.array = append([]int(nil), this.original...)
return this.original
}
func (this *Solution) Shuffle() []int {
rand.Seed(time.Now().UnixNano())
for i := range this.array {
randIndex := rand.Intn(len(this.array)-i) + i
this.array[i], this.array[randIndex] = this.array[randIndex], this.array[i]
}
return this.array
}Explanation
Algorithm
Постройте хеш-таблицу, где ключами являются символы строки, а значениями — количество их появлений. Для этого пройдите по строке и для каждого символа увеличивайте его счетчик в хеш-таблице.
Пройдите по строке снова и проверьте для каждого символа, является ли его количество появлений в хеш-таблице равным 1.
Если найдется символ с количеством появлений, равным 1, верните его индекс. Если такой символ не найден, верните -1.
😎