妹子留下的联系方式

2019-04-13  本文已影响0人  peerben
261555067548_.pic.jpg

如果直接用数组做filter, reduce, 内存会溢出, yield是个好东西.

中间想用rx来做, 既然学了, 第一直觉是用rx, 但是发现一个单步应用, 真没必要rx异步起来, 回调自己看着都麻烦, 程序就需要嵌套了.

最后的求3出现的次数, 如果计算量再大了, 就需要用java或go的forkjoin来做了, 单线程的node显然不合适, 除非spawn多个进程

看来有必要学一下go, 多线程, 协程是个好东西.

import { take } from "./utils";
import { from, Scheduler, Observable, identity } from "rxjs";
import { filter, toArray } from "rxjs/operators";
import { async } from "rxjs/internal/scheduler/async";
import { stringify } from "querystring";


function *prime(max: number): IterableIterator<any>{
  for (let cur = 1; cur < max; cur += 1) {
    const sqrt = Math.ceil(Math.sqrt(cur));

    let i = 2;
    for (; i<=sqrt; i++) {
      if (cur % i === 0) {
        break;
      }
    }

    if (i > sqrt) {
      yield cur;
    } 
  }
}

function findModZero(primeNum: number, primeGen: any) {
  let { value, done } = primeGen.next();

  while (!done) {
    const mod = primeNum % value;
    if (value > 1 && mod === 0) {
      return value;
    }
  
    const next = primeGen.next();
    value = next.value;
    done = next.done;
  }

  return;
}

function composePrime(primeNum: number, divNum: number) {
  const res = primeNum / divNum;

  // desc
  const joinRes = [divNum, res].sort((a, b) => b - a).join('');
  return joinRes;
}

function *numGenerator(max: number) {
  let i = 1;
  while (i < max) {
    if (i % 2 === 1) {
      yield i;
    }
    i++;
  }
}

function occuranceThree(num: number)  {
  const digitalList = num.toString().split('');
  return digitalList.reduce((acc, dig) => {
    if (dig === '3') acc += 1;
    return acc;
  }, 0);
}

function totalOccurance(num: number)  {
  let count = 0;
  const numGen = numGenerator(num);
  let { value, done } = numGen.next();

  while (!done) {
    const occCount = occuranceThree(value);
    //console.log(`cur ${value}, three occ ${occCount}, count ${count}`);
    count += occCount;

    const next = numGen.next();
    value = next.value;
    done = next.done;
  }

  return count;
}

const begin = +new Date();

const primeNum = 707829217;
const primeGen = prime(Math.sqrt(primeNum));
const modZero = findModZero(primeNum, primeGen);
const primeStr = composePrime(primeNum, modZero);
const threeCount = totalOccurance(Number(primeStr));

const end = +new Date();

console.log(`join prime ${primeStr}`);
console.log(`threeCount ${threeCount}`);

console.log(`run consume ${(end-begin)/1000} secs`);

/*
do {
  const { value, done } = primeGen.next();
  if (done) break;

  const mod = primeNum % value;
  if (value > 1 && mod === 0) {
    break;
  }
} while (true)
*/

/*
const source$ = Observable.create((observer: any) => {
  let p = 1;
  do {
    const { value, done } = primeGen.next(p);
    if (done) break;

    p = value;
    observer.next(value);
  } while (true);
});

source$.pipe(
  filter((v: number) => {
    const mod = primeNum % v;
    //console.log(`prime ${v} mod ${mod}`);
    
    return v > 1 && mod === 0;
  }),
).subscribe((x: any) => {
  const ano = primeNum / x;

  const res = [x, ano].sort((a, b) => b-a).join('');

  console.log(`res ${res}`);
});
*/

/*
const pg = Array.from(primeGen);
console.log(`pg ${pg}`);
*/

/*
from(primeGen, async).pipe(
  filter((v) => {
    const mod = primeNum % v;
    console.log(`prime ${v} mod ${mod}`);
    
    return mod === 0;
  }),
  toArray()
).subscribe(x => {
  console.log(`filter ${JSON.stringify(x)}`);
});
*/
//console.log(`prime ${JSON.stringify(Array.from(primeGen))}`)


/*
const primeList = Array.from(prime(707829217));
console.log(`primeList ${primeList}`);
*/


/*
function *generator() {
  let i = 0;
  while (i < 100) {
    yield i;
    i += 1;
  }
}

const gen = generator();
console.log(`gen ${Array.from(gen)}`);
*/


/*
from(generator(), async).pipe(
  filter((v) => {
    return v % 2 === 0;
  }),
  toArray()
).subscribe((x) => console.log(x));
*/
Screen Shot 2019-04-13 at 12.07.55 PM.png

哈哈, 本地开的进程有点多, 一个阿里云低配竟然比在本地跑的快

Screen Shot 2019-04-13 at 12.08.53 PM.png
上一篇 下一篇

猜你喜欢

热点阅读