题解 | #数据分类处理#

数据分类处理

http://www.nowcoder.com/practice/9a763ed59c7243bd8ab706b2da52b7fd

这个题目如果把思路理清了就不难,主要是处理起来比较麻烦。我的思路是先用2个vector<int>存输入(即题目中的I和R序列),v2排序去重之后,将v1、v2转换成vector<string>,方便查找子串。然后初始化一个长度为v2.size()的数组nums,用来存每个v2元素在v1中对应满足条件的个数;初始化一个v2.size()*v1.size()的二维数组array,用来存v1中满足条件的元素下标。这样对每个v2中的元素v2[i],在v1中对应元素的个数为nums[i],下标遍历array[i]就能得到。
上述方法还可省一点空间,就是不要nums,因为nums[i]的值就是array[i].size()的值。</string></int>

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;

string itoa(int n){
    string ans="";
    if(n==0)    return "0";
    while(n){
        ans+=n%10+'0';
        n/=10;
    }
    reverse(ans.begin(), ans.end());
    return ans;
}

int main(){
    int n1,n2;
    long long n;
    while(cin>>n1){
        vector<long long> v1,v2;
        vector<string> s1,s2;
        for(int i=0;i<n1;i++){
            cin>>n;
            v1.push_back(n);
        }
        cin>>n2;
        for(int i=0;i<n2;i++){
            cin>>n;
            v2.push_back(n);
        }
        sort(v2.begin(),v2.end());
        v2.erase(unique(v2.begin(),v2.end()), v2.end());

        vector<int> nums(v2.size(),0);//存v2中每个元素在v1中满足条件的个数
        vector<vector<int>> array(v2.size());//v1中满足条件的元素对应的位置
        //转换成字符串处理
        for(int i=0;i<n1;i++){
            s1.push_back(itoa(v1[i]));
        }
        for(int i=0;i<v2.size();i++){
            s2.push_back(itoa(v2[i]));
        }
        string::size_type pos;
        for(int i=0;i<v2.size();i++){
            for(int j=0;j<n1;j++){
                pos = s1[j].find(s2[i]);
                if(pos!=string::npos){
                    nums[i]++;
                    array[i].push_back(j);
                }
            }
        }

        //打印输出
        int res=0;
        for(int i=0;i<v2.size();i++){
            if(array[i].size()!=0){
                res+=2+2*array[i].size();
            }
        }
        cout<<res;
        for(int i=0;i<v2.size();i++){
            if(array[i].size()!=0){
                cout<<' '<<v2[i]<<' '<<array[i].size();
                for(int j=0;j<array[i].size();j++){
                    cout<<' '<<array[i][j]<<' '<<v1[array[i][j]];
                }
            }
        }
        cout<<endl;
    }

    return 0;
}
全部评论

相关推荐

听说改名字就能收到offer哈:Radis写错了兄弟
点赞 评论 收藏
分享
评论
点赞
收藏
分享
正在热议
# 25届秋招总结 #
442240次浏览 4509人参与
# 春招别灰心,我们一人来一句鼓励 #
41913次浏览 531人参与
# 阿里云管培生offer #
120204次浏览 2219人参与
# 地方国企笔面经互助 #
7961次浏览 18人参与
# 同bg的你秋招战况如何? #
76585次浏览 561人参与
# 虾皮求职进展汇总 #
115499次浏览 886人参与
# 北方华创开奖 #
107422次浏览 599人参与
# 实习,投递多份简历没人回复怎么办 #
2454609次浏览 34856人参与
# 实习必须要去大厂吗? #
55761次浏览 961人参与
# 提前批简历挂麻了怎么办 #
149889次浏览 1977人参与
# 投递实习岗位前的准备 #
1195913次浏览 18548人参与
# 你投递的公司有几家约面了? #
33203次浏览 188人参与
# 双非本科求职如何逆袭 #
662189次浏览 7394人参与
# 如果公司给你放一天假,你会怎么度过? #
4751次浏览 55人参与
# 机械人春招想让哪家公司来捞你? #
157622次浏览 2267人参与
# 如果你有一天可以担任公司的CEO,你会做哪三件事? #
11535次浏览 284人参与
# 发工资后,你做的第一件事是什么 #
12682次浏览 62人参与
# 工作中,努力重要还是选择重要? #
35793次浏览 384人参与
# 参加完秋招的机械人,还参加春招吗? #
20120次浏览 240人参与
# 我的上岸简历长这样 #
452000次浏览 8088人参与
# 实习想申请秋招offer,能不能argue薪资 #
39289次浏览 314人参与
# 非技术岗是怎么找实习的 #
155866次浏览 2120人参与
牛客网
牛客企业服务