Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Commit 9d23c3c

Browse files
authored
Merge pull request #379 from dipti95/TypeScript_Javascript_solutions
twoSum and graphValidTree solutions
2 parents f9cb77c + 7f59c0e commit 9d23c3c

File tree

2 files changed

+53
-0
lines changed

2 files changed

+53
-0
lines changed

typescript/1-Two-Sum.ts

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
function twoSum(nums: number[], target: number): number[] {
2+
let hash: { [key: number]: number } = {}
3+
for (let i = 0; i < nums.length; i++) {
4+
let diff = target - nums[i]
5+
if (diff in hash) {
6+
return [hash[diff], i]
7+
} else {
8+
hash[nums[i]] = i
9+
}
10+
}
11+
}

typescript/261-Graph-Valid-Tree.ts

Lines changed: 42 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,42 @@
1+
interface Obj {
2+
[key: number]: Array<number>
3+
}
4+
5+
interface Visited {
6+
[key: number]: boolean
7+
}
8+
9+
function validTree(n: number, edges: number[][]): boolean {
10+
if (n === 0) return true
11+
12+
let adjacent: Obj = {}
13+
let visited: Visited = {}
14+
for (let i = 0; i < n; i++) {
15+
adjacent[i] = []
16+
}
17+
18+
for (const val of edges) {
19+
const [n1, n2] = val
20+
adjacent[n1].push(n2)
21+
adjacent[n2].push(n1)
22+
}
23+
24+
return dfs(0, -1, visited, adjacent) && Object.keys(visited).length === n
25+
}
26+
27+
function dfs(
28+
node: number,
29+
prevNode: number,
30+
visited: Visited,
31+
adjacent: Obj
32+
): boolean {
33+
if (visited[node]) return false
34+
visited[node] = true
35+
36+
for (const ele of adjacent[node]) {
37+
if (ele === prevNode) continue
38+
if (!dfs(ele, node, visited, adjacent)) return false
39+
}
40+
41+
return true
42+
}

0 commit comments

Comments
 (0)