三道编程题题解代码如下:
牛牛A+B
class Solution { public: long long NNAplusB(int a, int b) { long long A = 0; long long B = 0; for(int i = 0 ; i < b; i ++) { A*=10; A+=a; } for(int i = 0 ; i < a; i ++) { B*=10; B+=b; } return A+B; } };
牛妹LIS
class Solution { public: int NS_LIS(string n) { int len = n.length(); int sum = 0; for(int i = 0 ; i < len ; i++) { sum+=n[i]-'0'; } return max(n[0]-'0'-1+9*(len-1),sum); } };
魔法师牛牛
struct node{ int num; int i; }; bool cmp(node a,node b) { return a.num<b.num; } class Solution { public: vector<int> Magical_NN(vector<int>& h) { vector<node> arr; int len = h.size(); for(int i = 0 ; i < len ; i++) { node t; t.num = h[i]; t.i = i; arr.push_back(t); } sort(arr.begin(),arr.end(),cmp); vector<int> sum(len);//前缀和 sum[0] = arr[0].num; long long SUM = arr[0].num; for(int i = 1 ; i < len ; i++) { sum[i] = sum[i-1]+arr[i].num; SUM+=arr[i].num; } vector<int> ans(len); ans[arr[0].i] = (SUM-sum[0] - arr[0].num*(len-1)); for(int i = 1 ; i < len ; i++) { ans[arr[i].i] = (arr[i].num*(i)-sum[i-1]) + (SUM-sum[i] - arr[i].num*(len-i-1)); } return ans; } };
【第二场模拟笔试预报名】
没有参加上这次模拟笔试的同学,7月将进行第二场的模拟笔试,一定不要错过了
7月场模拟笔试时间:预计7月中下旬,具体时间还未定
报名方式:
牛客题库-模拟笔试页面
收藏以上链接,报名入口预计下个月开放
如果怕忘记,也可以添加下方丸子老师微信,老师会在开放报名之后,及时提醒大家的:
全部评论
(2) 回帖