Loading...
More TypeScript Posts
const langToConfig = {'javascript': {image: '',cmd: ['']},'php': {image: '',cmd: ['']},}
interface Task {id: number;title: string;completed: boolean;}class TaskManager {private tasks: Task[] = [];constructor() {}addTask(title: string) {const taskId = this.tasks.length + 1;const task: Task = {id: taskId,title,completed: false,};this.tasks.push(task);}markTaskAsComplete(taskId: number) {const task = this.tasks.find((task) => task.id === taskId);if (task) {task.completed = true;}}markTaskAsIncomplete(taskId: number) {const task = this.tasks.find((task) => task.id === taskId);if (task) {task.completed = false;}}listTasks() {console.log('Tasks:');this.tasks.forEach((task) => {console.log(`${task.id}. [${task.completed ? 'X' : ' '}] ${task.title}`);});}}// Example usage:const taskManager = new TaskManager();taskManager.addTask('Buy groceries');taskManager.addTask('Pay bills');taskManager.addTask('Clean the house');taskManager.listTasks();// Output:// Tasks:// 1. [ ] Buy groceries// 2. [ ] Pay bills// 3. [ ] Clean the house
class DFS{public dfs(G: DFSGraph, startVert: number){let visited: boolean[] = Array<boolean>();// Pre-populate array:for(let i = 0; i < G.size; i++){visited.push(false);}let s: number[] = new Array();visited[startVert] = true;s.push(startVert);while(s.length > 0){const v = s.pop();for(let adjV of G.adj[v]){if(!visited[adjV]){visited[adjV] = true;s.push(adjV);}}}}public dfsRecursive(G: DFSGraph, startVert: number){let visited: boolean[] = Array<boolean>();// Pre-populate array:for(let i = 0; i < G.size; i++){visited.push(false);}this.dfsAux(G, startVert, visited);}private dfsAux(G: DFSGraph, v: number, visited: boolean[]){visited[v] = true;for(let adjV of G.adj[v]){if(!visited[adjV]){// this.foo(); // Something can happen before the visit.this.dfsAux(G, adjV, visited);// this.bar(); // Something can happen after the visit.}}}}
// This function takes a matrix and outputs 4 equal size submatrices, starting from top left going to bottom right.const split = (matrix: number[][]): number[][][] => {const n: number = matrix.lengthconst mid: number = n/2const C11: number[][] = new Array<Array<number>> // first n/2 rows intersection first n/2 colummsconst C12: number[][] = new Array<Array<number>> // first n/2 rows intersection last n/2 columnsconst C21: number[][] = new Array<Array<number>> // last n/2 rows intersection first n/2 columnsconst C22: number[][] = new Array<Array<number>> // last n/2 rows intersection last n/2 columnsfor(let i: number = 0; i < mid; i++) {C11.push([])C12.push([])for (let j: number = 0; j < mid; j++) {C11[i].push(matrix[i][j])}for (let j: number = mid; j < n; j++) {C12[i].push(matrix[i][j])}}for(let i: number = 0; i < mid; i++) {C21.push([])C22.push([])for (let j: number = 0; j < mid; j++) {C21[i].push(matrix[i+mid][j])}for (let j: number = mid; j < n; j++) {C22[i].push(matrix[i+mid][j])}}return [C11, C12, C21, C22]}// This function takes 4 matrices, in order from top left to bottom right, and combines them into one matrixconst combine = (A: number[][], B: number[][], C: number[][], D: number[][]): number[][] => {const n: number = A.length*2const combo: number[][] = new Array<Array<number>>// Populate combo with temporary 0sfor(let i: number = 0; i < A.length; i++) {combo.push([])for (let j: number = 0; j < A.length; j++) {combo[i].push(A[i][j])}for (let j: number = A.length; j < n; j++) {combo[i].push(B[i][j-A.length])}}for(let i: number = A.length; i < n; i++) {combo.push([])for (let j: number = 0; j < A.length; j++) {combo[i].push(C[i-A.length][j])}for (let j: number = A.length; j < n; j++) {combo[i].push(D[i-A.length][j-A.length])}}return combo}// Basic matrix addition functionconst matrix_add = (A: number[][], B: number[][]): number[][] => {const matrix_sum: number[][] = [[]]const n: number = A.lengthfor(let i: number = 0; i < n; i++) {matrix_sum[i] = []for (let j: number = 0; j < n; j++) {matrix_sum[i][j] = A[i][j] + B[i][j]}}return matrix_sum}// Basic matrix subtraction functionconst matrix_subtract = (A: number[][], B: number[][]): number[][] => {const matrix_diff: number[][] = [[]]const n: number = A.lengthfor(let i: number = 0; i < n; i++) {matrix_diff[i] = []for (let j: number = 0; j < n; j++) {matrix_diff[i][j] = A[i][j] - B[i][j]}}return matrix_diff}const strassen = (A: number[][], B: number[][]): number[][] => {const n: number = A.lengthvar C: number[][] = [[]]// Populate C with temporary 0sfor(let i: number = 0; i < n; i++) {C[i] = []for (let j: number = 0; j < n; j++) {C[i][j] = 0}}// Once the matrices reach a small enough size, compute using the brute force methodif (n <= 2) {for (let i: number = 0; i < n; i++) {for (let j: number = 0; j < n; j++) {for (let z: number = 0; z < n; z++) {C[i][j] = C[i][j] + (A[i][z]*B[z][j])}}}return C}// Create independent variables from function that returns an array with array destructuring.const [a, b, c, d] = split(A)const [e, f, g, h] = split(B)// Using Strassen's method to calculate 1 less productconst p1: number[][] = strassen(matrix_add(a, d), matrix_add(e,h))const p2: number[][] = strassen(d, matrix_subtract(g, e))const p3: number[][] = strassen(matrix_add(a, b), h)const p4: number[][] = strassen(matrix_subtract(b, d), matrix_add(g, h))const p5: number[][] = strassen(a, matrix_subtract(f, h))const p6: number[][] = strassen(matrix_add(c, d), e)const p7: number[][] = strassen(matrix_subtract(a, c), matrix_add(e, f))const C11: number[][] = matrix_add(matrix_subtract(matrix_add(p1, p2), p3), p4)const C12: number[][] = matrix_add(p5, p3)const C21: number[][] = matrix_add(p6, p2)const C22: number[][] = matrix_subtract(matrix_subtract(matrix_add(p5, p1), p6), p7)C = combine(C11, C12, C21, C22)return C}const M1: number[][] = [[1,3],[7,5]]const M2: number[][] = [[6,8],[4,2]]const M_Product: number[][] = strassen(M1, M2)console.log("Matrix 1:")console.log(M1)console.log("Matrix 2:")console.log(M2)console.log("Product: ")console.log(M_Product)
import React, { useEffect, useRef, useState } from 'react';import * as d3 from 'd3';export default function useD3(renderChartFn : (svg : d3.Selection<SVGElement,{},HTMLElement>) => any, dependencies : any[]) {const ref = useRef<SVGSVGElement>();useEffect(() => {let d3El = d3.select(ref.current)renderChartFn(d3.select(ref.current));return () => {};}, dependencies);return ref;}function MyChart(props : {w: number,h: number,data: Array<any>}) {const [currentData,setCurrentData] = useState(props.data)let svgRef = useD3((svg) => {if (props.data === currentData) returnsetCurrentData(props.data)// add d3 codesvg.selectAll("*").remove();const margin = { top: 0, right: 80, bottom: 20, left: 10 };const width = props.w - margin.left - margin.right;const height = props.h - margin.top - margin.bottom;const canvas = svg.attr('width', width + margin.left + margin.right).attr('height', height + margin.top + margin.bottom).append('g').attr('transform', `translate(${margin.left},${margin.top})`);// dataconst data = props.data},[props])return (<svg ref={svgRef} />)}
class DFS{public dfs(G: DFSGraph, startVert: number){let visited: boolean[] = Array<boolean>();// Pre-populate array:for(let i = 0; i < G.size; i++){visited.push(false);}let s: number[] = new Array();visited[startVert] = true;s.push(startVert);while(s.length > 0){const v = s.pop();for(let adjV of G.adj[v]){if(!visited[adjV]){visited[adjV] = true;s.push(adjV);}}}}public dfsRecursive(G: DFSGraph, startVert: number){let visited: boolean[] = Array<boolean>();// Pre-populate array:for(let i = 0; i < G.size; i++){visited.push(false);}this.dfsAux(G, startVert, visited);}private dfsAux(G: DFSGraph, v: number, visited: boolean[]){visited[v] = true;for(let adjV of G.adj[v]){if(!visited[adjV]){// this.foo(); // Something can happen before the visit.this.dfsAux(G, adjV, visited);// this.bar(); // Something can happen after the visit.}}}}