【编程练习】字节跳动笔试题04猫咪特征

这是一道编程题,要求从猫咪视频的每一帧中提取猫咪的特征,并寻找最长的连续特征运动。题目中提到,特征是一个二维坐标向量,如果在连续的帧中出现相同的特征,就构成了特征运动。任务是给定各帧的特征,找出最长的特征运动序列。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

(编程题) 小明是一名算法工程师,同时也是一名铲屎官。某天,他突发奇想,想从猫咪的视频里挖掘一些猫咪的运动信息。为了提取运动信息,他需要从视频的每一帧提取“猫咪特征”。一个猫咪特征是一个两维的vector<x, y>。如果x_1=x_2 and y_1=y_2,那么这俩是同一个特征。
因此,如果喵咪特征连续一致,可以认为喵咪在运动。也就是说,如果特征<a, b>在持续帧里出现,那么它将构成特征运动。比如,特征<a, b>在第2/3/4/7/8帧出现,那么该特征将形成两个特征运动2-3-4 和7-8。
现在,给定每一帧的特征,特征的数量可能不一样。小明期望能找到最长的特征运动。

参考代码

n = int(input())

while n > 0:
    m = int(input())
    res = 1
    d = {}
    for i in range(m):
        l = list(map(int , input().split()))
        k = l[0]
        tmp_d = {}
        for j in range(k):
            index = l[2 * j + 1] * 1000000000 + l[2 * j + 2]
            if index in d:
                tmp_d[index] = d[index] + 1
                res = max(res, tmp_d[index])
            else:
                tmp_d[index] = 1
        d = tmp_d
    print(res)
    n -= 1

c++版

map套set 存进去之后找连续的
#include<iostream>
#include<algorithm>
#include<cstring>
#include<map>
#include<bits/stdc++.h>
using namespace std;
map< pair<int,int>, set<int> > m1;
int main()
{
  //  freopen("in","r",stdin);
    int n,m;
    cin>>n;
    while(n--){
        cin>>m;
        int maxn=0,now=0;
        int k;
        int x,y;
        for(int i=0;i<m;i++){
            cin>>k;
            for(int j=0;j<k;j++){
                cin>>x>>y;
                m1[make_pair(x,y)].insert(i);
            }
        }
        for(map <pair<int,int>, set<int> >::iterator it=m1.begin();it!=m1.end();it++){
            int num=0;
            int sum=1;
            set<int>::iterator itt=it->second.begin();
            num=*itt;
            itt++;
            for(;itt!=it->second.end();itt++){
                if(*itt==num+1){
                    sum++;
                    num=*itt;
                    }
                    else 
                    {
                    	num=*itt;
                    	maxn=max(maxn,sum);
                    	sum=1;
                	}
            	}
            	if(itt==it->second.end()) maxn=max(maxn,sum);
        	}
        	cout<<max(maxn,now)<<endl;
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值