【通知】7月22,工业界资深数据科学家教你破解各大公司面试!


一亩三分地论坛

 找回密码
 获取更多干活,快来注册

一亩三分地官方iOS手机应用下载
查看: 1361|回复: 1
收起左侧

Twitter OA 人品爆发 超级简单 附这两天收集的题目

[复制链接] |试试Instant~ |关注本帖
singku 发表于 2016-3-21 04:11:03 | 显示全部楼层 |阅读模式

2016(1-3月) 码农类 硕士 实习@Twitter - 网上海投 - 在线笔试 |Other其他

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?获取更多干活,快来注册

x
这两天在地里逛了下 做了一些OA题,今天做OA预期会遇到变态的数论题,于是周末好好准备了一下但是没有遇到,人品好!-google 1point3acres
.鏈枃鍘熷垱鑷1point3acres璁哄潧
俩题目是 1、算阶乘。 2、判定是否合法的国旗。
c++写的
1、感觉阶乘这个唯一要处理的就是输入输出,test case虽然都会有一个非正数输入让你结束
但个人感觉还是要处理下不是非整数结束的输入


2、国旗这个就是 N*M的矩阵,每一行内的元素都要相同,相邻行的元素不能相同。


下面附带自己最近收集的Twitter OA的题及自己写的代码
  1. //N=p^q
  2. bool super_power(unsigned long long int n) {
  3.       for (unsigned long long int p = sqrt(n); p > 1; p--) {
  4.             if (pow(p, (int)(log(n)/log(p))) == n) {.鏈枃鍘熷垱鑷1point3acres璁哄潧
  5.             cout << p << "_" << log(n)/log(p) << endl;
  6.             return true;
  7.         }
  8.     }. Waral 鍗氬鏈夋洿澶氭枃绔,
  9.     return false;
  10. }. 鍥磋鎴戜滑@1point 3 acres

  11. //n lines cut plain to x parts
  12. int n_cuts(int n) {
  13.         //f(n) = f(n-1) + n;
  14.         //f(n) = (2+n*n + n)/2;
  15.         return (2 + n + n * n) / 2;
  16. }

  17. // game of thrones
  18. bool palindrome_permutation(string &s)
  19. {
  20.     int n = s.size();. 1point3acres.com/bbs
  21.     int table[26] = {0};
  22.     int odds = 0;.1point3acres缃
  23.     for (int i = 0; i < n; i++) {
  24.         table[s[i]-'a'] = (table[s[i]-'a'] + 1) % 2;
  25.         odds += (table[s[i]-'a'] ?1 :-1);
  26.     }
  27.     return (odds <= 1);
  28. }

  29. // valid flag
  30. int main() {
  31.     /* Enter your code here. Read input from STDIN. Print output to STDOUT */  
  32.     int t;
  33.     cin >> t;
  34.     for (int i = 0; i < t; i++) {
  35.         int n, m;
  36.         cin >> n >> m;
  37.         vector<string> strvec;
  38.         for (int j = 0; j < n; j++) {
  39.             string cur;
  40.             cin >> cur;
  41.             cout << cur << endl;
  42.             strvec.push_back(cur);. from: 1point3acres.com/bbs
  43.         }
  44.         bool valid = true;
  45.         for (int j = 0; j < n; j++) {. visit 1point3acres.com for more.
  46.             if (strvec[j].size() != m) {
  47.                 valid = false;
  48.                 break;
  49.             }
  50.             for (int k = 0; k < m-1; k++) {. 鍥磋鎴戜滑@1point 3 acres
  51.                 if (strvec[j][k] != strvec[j][k+1]) {. 1point3acres.com/bbs
  52.                     valid = false;.1point3acres缃
  53.                     break;
  54.                 }
  55.             }
  56.             if (valid == false) {
  57.                 break;
  58.             }
  59.             if (j != 0 && strvec[j-1][0] == strvec[j][0]) {
  60.                 valid = false;
  61.                 break;
  62.             }
  63.         }
  64.         cout << (valid ?"YES" :"NO") << endl;
  65.     }. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
  66.     return 0;
  67. }

  68. //gcd
  69. int gcd(int a, int b) {
  70.     while (a != b) {
  71.         int d = fabs(a-b);
  72.         a = min(a, b);
  73.         b = d;
  74.     }
  75.     return a;
  76. }

  77. // common elements in array
  78. int common_elements(int start, int step, int end, int start1, int factor, int end1) {
  79.         int cnt = 0;
  80.         for (int i = start1, i <= end1 && i <= end, i *= factor) {
  81.                 if (i < start) continue;
  82.                 if ((i - start) % step == 0) cnt++;.1point3acres缃
  83.         }
  84.         return cnt;
    . 1point3acres.com/bbs
  85. }

  86. // count primes + 1 = # of x fufill (x-1)! % x == x-1
  87. int countPrimes(int n) {
  88.         if (n <= 2) {
  89.                 return 0;
  90.         }
  91.         //only test odd number start from 3 to n;
  92.         //idx = num-1/2 - 1 ; 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
  93.         char bitmap[n] = {0};
  94.         int count = 1;
  95.         int upper = sqrt(n);
  96.         for (int i = 3; i < n; i += 2) {
  97.                 if (bitmap[i] == 0) {//i is prime
  98.                         count++;
  99.                         if (i > upper) continue;
  100.                         for (int j = i*i; j < n; j += 2*i) {
  101.                                 bitmap[j] = 1;//j is not prime;
  102.                         }-google 1point3acres
  103.                 }
  104.         }
  105.         return count;. 鍥磋鎴戜滑@1point 3 acres
  106. }

  107. // first repeating
  108. char first_repeating_char(string &s) {
  109.         int n = s.size();
  110.         int pos = n;
  111.         int table[256][2] = {0};
  112.         for (int i = 0; i < n; i++) {
  113.                 int idx = s[i];
  114.                 if (table[idx][0] == 0) {
  115.                         table[idx][1] = i; //first appearance
  116.                 }
  117.                 if (++table[idx][0] == 2) {//repeat
  118.                         pos = min(pos, table[idx][1]);
  119.                 }
  120.         }
  121.         return pos < n ?' ' : s[pos];
  122. }
  123. . more info on 1point3acres.com
  124. //euler function mutual prime less than n. 1point3acres.com/bbs
  125. int mutual_prime_cnt(int n) {
  126.         double ans;
  127.         int temp = n;
  128.         ans = n;
  129.         for(int i = 2; i*i <= n; i++) {. more info on 1point3acres.com
  130.                 if(n % i == 0){. 鍥磋鎴戜滑@1point 3 acres
  131.                         ans = ans / i * (i-1);
  132.                         n /= i;
  133.                         while( n%i == 0)        n/=i;. 1point 3acres 璁哄潧
  134.                 }.鏈枃鍘熷垱鑷1point3acres璁哄潧
  135.         }
  136.         if(n != 1 ) {
  137.                 ans = ans/n*(n-1); 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
  138.         }-google 1point3acres
  139.         return (temp == 1 ?0 :ans);
  140. }.1point3acres缃

  141. //closet numbers
  142. int main() {
  143.     /* Enter your code here. Read input from STDIN. Print output to STDOUT */   
  144.     int n;
  145.     cin >> n;
  146.     vector<int> array;-google 1point3acres
  147.     for (int i = 0; i < n; i++) {
  148.         int a;
  149.         cin >> a;. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
  150.         array.push_back(a);
  151.     }
  152.     sort(array.begin(), array.end());
  153.     int min_d = 0x7FFFFFFF;
  154.     for (int i = 0; i < n-1; i++) {
  155.         if (array[i+1] - array[i] <= min_d) {
  156.             min_d = array[i+1] - array[i];
  157.         }
  158.     }
  159.     for (int i = 0; i < n-1; i++) {
  160.         if (array[i+1] - array[i] == min_d) {
  161.             cout << array[i] << " " << array[i+1] << " ";
  162.         }
  163.     }
  164.     return 0;
  165. }
复制代码

评分

2

查看全部评分

aifer 发表于 2016-3-21 04:44:26 | 显示全部楼层
关注一亩三分地公众号:
Warald_一亩三分地
请问楼主,你有delete substring的代码么
回复 支持 反对

使用道具 举报

本版积分规则

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明

custom counter

GMT+8, 2017-7-21 18:58

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表