首页 > 8.22 腾讯笔试(神奇格子)投票 +(4.3/5.0)代码
头像
这个昵称与你无缘
编辑于 2021-08-24 00:51
+ 关注

8.22 腾讯笔试(神奇格子)投票 +(4.3/5.0)代码 投票


最后一题完全不会做,暴力都不会暴力,骗了30%。。。。。。。

A. 没啥难度,但是如果开vector[50000]这种C++会内存超限,非常恶心,所以直接用链表存了
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     * 
     * @param m int整型 
     * @param a ListNode类 指向彩带的起点,val表示当前节点的val,next指向下一个节点
     * @return ListNode类vector
     */
    /*vector<int>vec[500005];
    vector<ListNode*> solve(int m, ListNode* a) {
        // write code here
        while(a!=NULL){
            vec[a->val%m].push_back(a->val);
            a = a->next;
        }
        
        vector<ListNode*>ans;
        for(int i=0;i<m;i++){
            int size = vec[i].size();
            if(size == 0)
                ans.push_back(NULL);
            else{
                ListNode* head = new ListNode(-1);
                ListNode* tmp = head;
                for(int j=0;j<size;j++){
                    ListNode* p = new ListNode(vec[i][j]);
                    tmp->next = p;
                    tmp = p;
                }
                ans.push_back(head->next);
            }
        }
        return ans;
    }*/
    vector<ListNode*>ans;
    map<int,ListNode*>t;
    vector<ListNode*> solve(int m, ListNode* a) {
        // write code here

        for(int i=0;i<m;i++){
            ListNode* h = new ListNode(-1);
            ans.push_back(h);
            t[i] = h;
        }
        while(a!=NULL){
            int dir = a->val%m;
            ListNode* n = new ListNode(a->val);
            ListNode* be = t[dir];
            be->next = n;
            t[dir] = n;
            a = a->next;
        }
        for(int i=0;i<m;i++){
            ListNode* be = ans[i];
            ans[i] = be->next;
        }

        return ans;
    }
};

B.N方过不了,标记一下到当前位置总共加了多少value即可,复杂度N
#include <bits/stdc++.h>

using namespace std;
#define ll long long

int t;
ll num[1005];
const ll mod = 1e9+7;
int main()
{
    scanf("%d",&t);
    while(t--){
        int n;
        scanf("%d",&n);
        for(int i=1;i<=n;i++)
               scanf("%lld",&num[i]);
        sort(num+1,num+1+n);
        ll ans = 0;
        ll sum = 0;
        for(int i=n;i>=1;i--)
        {
                num[i] = (num[i] + sum)%mod;
                ans = (ans + num[i])%mod;
                sum = (sum + num[i])%mod;
        }
        printf("%lld\n",ans);
    }
    return 0;
}

C.注意总和是偶数,那只能是奇数+奇数或者偶数+偶数,所以将所有的数字分成两个部分去各位判断即可,我一开始还以为是二分图。。
#include <bits/stdc++.h>

using namespace std;
#define ll long long

int t;
int even[1005];
int odd[1005];
int main()
{
    scanf("%d",&t);
    while(t--){
        int n,m;
        scanf("%d%d",&n,&m);
        int oc = 0;
        int ec = 0;
        for(int i=1;i<=n;i++)
        {
                int tmp;
                scanf("%d",&tmp);
                if(tmp%2==1)
                        odd[++oc] = tmp;
                else
                        even[++ec] = tmp;
        }

        int ans = n;
        sort(even+1,even+1+ec);
        sort(odd+1,odd+1+oc);
        int l = 1,r=oc;
        while(l<r){
                while(l<r){
                        if(odd[l]+odd[r]<=m)
                        {
                                ans--;
                                r--;
                                break;
                        }
                        r--;
                }
                l++;
        }

        l=1,r=ec;
        while(l<r){
                while(l<r){
                        if(even[l]+even[r]<=m)
                        {
                                ans--;
                                r--;
                                break;
                        }
                        r--;
                }
                l++;
        }
        printf("%d\n",ans);
    }
    return 0;
}

D. 找字典序最大,对于每一位枚举最大的区间找最大的字符即可
#include <bits/stdc++.h>

using namespace std;
#define ll long long

int n,k;
int main()
{
    scanf("%d%d",&n,&k);
    string str;
    cin>>str;

    string ans = "";
    int len = str.length();
    int now = 0;

    /*i 后面 还有 k-i
    至少要留出k-i个字符
    len - 1
    len - k + i*/
    for(int i=1;i<=k;i++){
        char large = 'a' - 1;
        int dir;
        for(int j=now;j<len-k+i;j++){
                if(large<str[j]){
                        large = str[j];
                        dir = j;
                }
        }
        ans.push_back(large);

        now = dir+1;
    }
    cout<<ans<<endl;
    return 0;
}

E.神奇格子。。。。。完全不会,骗了30%,代码不放了没有必要



全部评论

(9) 回帖
加载中...
话题 回帖

相关热帖

历年真题 真题热练榜 24小时
技术(软件)/信息技术类
查看全部

热门推荐