一亩三分地论坛

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

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

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

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

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

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

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

x
这两天在地里逛了下 做了一些OA题,今天做OA预期会遇到变态的数论题,于是周末好好准备了一下但是没有遇到,人品好!

俩题目是 1、算阶乘。 2、判定是否合法的国旗。
c++写的. from: 1point3acres.com/bbs
1、感觉阶乘这个唯一要处理的就是输入输出,test case虽然都会有一个非正数输入让你结束
但个人感觉还是要处理下不是非整数结束的输入. from: 1point3acres.com/bbs


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


下面附带自己最近收集的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;
  6.             return true;
  7.         }
  8.     }
  9.     return false;
  10. }-google 1point3acres

  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();
  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;.鏈枃鍘熷垱鑷1point3acres璁哄潧
  25.         odds += (table[s[i]-'a'] ?1 :-1);. more info on 1point3acres.com
  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;. 鍥磋鎴戜滑@1point 3 acres
  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); 鏉ユ簮涓浜.涓夊垎鍦拌鍧.
  43.         }
  44.         bool valid = true;. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  45.         for (int j = 0; j < n; j++) {-google 1point3acres
  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]) {. 1point3acres.com/bbs
  52.                     valid = false;
  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.         }. from: 1point3acres.com/bbs
  64.         cout << (valid ?"YES" :"NO") << endl;
  65.     }. 鍥磋鎴戜滑@1point 3 acres
  66.     return 0;
  67. }. From 1point 3acres bbs

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

  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;-google 1point3acres
  80.         for (int i = start1, i <= end1 && i <= end, i *= factor) {
  81.                 if (i < start) continue;
  82.                 if ((i - start) % step == 0) cnt++;
  83.         }. 1point 3acres 璁哄潧
  84.         return cnt;
  85. }
  86. -google 1point3acres
  87. // count primes + 1 = # of x fufill (x-1)! % x == x-1
  88. int countPrimes(int n) {
  89.         if (n <= 2) {
  90.                 return 0;
    .鐣欏璁哄潧-涓浜-涓夊垎鍦
  91.         }
  92.         //only test odd number start from 3 to n;.鏈枃鍘熷垱鑷1point3acres璁哄潧
  93.         //idx = num-1/2 - 1 ;
  94.         char bitmap[n] = {0};
  95.         int count = 1;
  96.         int upper = sqrt(n);
  97.         for (int i = 3; i < n; i += 2) {
  98.                 if (bitmap[i] == 0) {//i is prime
  99.                         count++;
  100.                         if (i > upper) continue;
  101.                         for (int j = i*i; j < n; j += 2*i) {
  102.                                 bitmap[j] = 1;//j is not prime;
  103.                         }. from: 1point3acres.com/bbs
  104.                 }
  105.         }
  106.         return count;. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  107. }.1point3acres缃

  108. // first repeating
  109. char first_repeating_char(string &s) {
  110.         int n = s.size();
  111.         int pos = n;
  112.         int table[256][2] = {0};
  113.         for (int i = 0; i < n; i++) {
  114.                 int idx = s[i];
  115.                 if (table[idx][0] == 0) {. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
  116.                         table[idx][1] = i; //first appearance
  117.                 }
  118.                 if (++table[idx][0] == 2) {//repeat
  119.                         pos = min(pos, table[idx][1]);
  120.                 }
  121.         }
    . 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  122.         return pos < n ?' ' : s[pos];
  123. }

  124. //euler function mutual prime less than n. visit 1point3acres.com for more.
  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++) {
  130.                 if(n % i == 0){
  131.                         ans = ans / i * (i-1);
  132.                         n /= i;
  133.                         while( n%i == 0)        n/=i;
  134.                 }
  135.         }
  136.         if(n != 1 ) {
  137.                 ans = ans/n*(n-1);
  138.         }. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  139.         return (temp == 1 ?0 :ans);
  140. }

  141. //closet numbers
  142. int main() {.1point3acres缃
  143.     /* Enter your code here. Read input from STDIN. Print output to STDOUT */   
  144.     int n;. 鍥磋鎴戜滑@1point 3 acres
  145.     cin >> n;
  146.     vector<int> array;
  147.     for (int i = 0; i < n; i++) {
  148.         int a;. from: 1point3acres.com/bbs
  149.         cin >> a;
  150.         array.push_back(a);
  151.     }
  152.     sort(array.begin(), array.end());. from: 1point3acres.com/bbs
  153.     int min_d = 0x7FFFFFFF;. from: 1point3acres.com/bbs
  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.         }. from: 1point3acres.com/bbs
  158.     }
  159.     for (int i = 0; i < n-1; i++) {
    . Waral 鍗氬鏈夋洿澶氭枃绔,
  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的代码么
回复 支持 反对

使用道具 举报

本版积分规则

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

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

关闭

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

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

custom counter

GMT+8, 2017-3-23 06:05

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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