一亩三分地论坛

 找回密码
 获取更多干货,去instant注册!

扫码关注一亩三分地公众号
查看: 1056|回复: 1
收起左侧

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

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

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

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

您需要 登录 才可以下载或查看,没有帐号?获取更多干货,去instant注册!

x
这两天在地里逛了下 做了一些OA题,今天做OA预期会遇到变态的数论题,于是周末好好准备了一下但是没有遇到,人品好!-google 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) {
  5.             cout << p << "_" << log(n)/log(p) << endl;.1point3acres缃
  6.             return true;
  7.         }
  8.     }
  9.     return false;
  10. }

  11. //n lines cut plain to x parts
  12. int n_cuts(int n) {
  13.         //f(n) = f(n-1) + n;. Waral 鍗氬鏈夋洿澶氭枃绔,
  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();
  21.     int table[26] = {0};. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  22.     int odds = 0;
  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++) {
    . Waral 鍗氬鏈夋洿澶氭枃绔,
  35.         int n, m;
  36.         cin >> n >> m;
  37.         vector<string> strvec;
    . 1point 3acres 璁哄潧
  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++) {
  46.             if (strvec[j].size() != m) {
  47.                 valid = false;
  48.                 break;
  49.             }. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  50.             for (int k = 0; k < m-1; k++) {
  51.                 if (strvec[j][k] != strvec[j][k+1]) {
  52.                     valid = false;
  53.                     break;
  54.                 }
  55.             }
  56.             if (valid == false) {
  57.                 break;
  58.             }.1point3acres缃
  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);.1point3acres缃
  72.         a = min(a, b);
  73.         b = d;. From 1point 3acres bbs
  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;
  85. }

  86. // count primes + 1 = # of x fufill (x-1)! % x == x-1 . visit 1point3acres.com for more.
  87. int countPrimes(int n) {
  88.         if (n <= 2) {
  89.                 return 0;.1point3acres缃
  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.                         }
  103.                 }
  104.         }. visit 1point3acres.com for more.
  105.         return count;
  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};-google 1point3acres
  112.         for (int i = 0; i < n; i++) {. 鍥磋鎴戜滑@1point 3 acres
  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. from: 1point3acres.com/bbs
  118.                         pos = min(pos, table[idx][1]);
  119.                 }
  120.         }
  121.         return pos < n ?' ' : s[pos];.鏈枃鍘熷垱鑷1point3acres璁哄潧
  122. }

  123. //euler function mutual prime less than n
  124. int mutual_prime_cnt(int n) {
  125.         double ans;. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  126.         int temp = n;
  127.         ans = n;.鐣欏璁哄潧-涓浜-涓夊垎鍦
  128.         for(int i = 2; i*i <= n; i++) {
  129.                 if(n % i == 0){
  130.                         ans = ans / i * (i-1);
  131.                         n /= i;
  132.                         while( n%i == 0)        n/=i;
  133.                 }.鏈枃鍘熷垱鑷1point3acres璁哄潧
  134.         }
  135.         if(n != 1 ) {
  136.                 ans = ans/n*(n-1);
  137.         }
  138.         return (temp == 1 ?0 :ans);
  139. }

  140. //closet numbers
  141. int main() { 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
  142.     /* Enter your code here. Read input from STDIN. Print output to STDOUT */   
  143.     int n;
  144.     cin >> n;
  145.     vector<int> array;
  146.     for (int i = 0; i < n; i++) {
  147.         int a;
  148.         cin >> a;
  149.         array.push_back(a);
  150.     }
  151.     sort(array.begin(), array.end());
  152.     int min_d = 0x7FFFFFFF;
  153.     for (int i = 0; i < n-1; i++) {
  154.         if (array[i+1] - array[i] <= min_d) {
  155.             min_d = array[i+1] - array[i];
  156.         }
  157.     }. 鍥磋鎴戜滑@1point 3 acres
  158.     for (int i = 0; i < n-1; i++) {
  159.         if (array[i+1] - array[i] == min_d) {
  160.             cout << array[i] << " " << array[i+1] << " ";
  161.         }
  162.     }
  163.     return 0;
  164. }
复制代码

评分

2

查看全部评分

aifer 发表于 2016-3-21 04:44:26 | 显示全部楼层
请问楼主,你有delete substring的代码么
回复 支持 反对

使用道具 举报

本版积分规则

请点这里访问我们的新网站:一亩三分地Instant.

Instant搜索更强大,不扣积分,内容组织的更好更整洁!目前仍在beta版本,努力完善中!反馈请点这里

关闭

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

手机版|小黑屋|一亩三分地论坛声明 ( 沪ICP备11015994号 )

custom counter

GMT+8, 2016-12-7 17:19

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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