P3613 【深基15.例2】寄包柜

P3613 【深基15.例2】寄包柜
题意:超市里有n个寄包柜。每个寄包柜格子数量不一,第i个寄包柜有 ai个格子。对于每个寄包柜,格子编号从1开始,一直到 ai。现在有q次操作:
1 i j k:在第i个柜子的第j个格子存入物品 k,当k=0时说明清空该格子。
2 i j:查询第i个柜子的第j个格子中的物品是什么,保证查询的柜子有存过东西。

分析:题目很容易懂,不过多解释,直接上方法。
一开始也想了几种方法,比如二维数组,单链表, map, pair等。二维数组空间超范围了,肯定不能用。想尝试用pair, 但好像没法实现两个值对应第三个值,查阅资料也没找到解决方式,应该不能这么用, 换map<int,map<int,int>>, 从网上搜了相关用法,还偶然了解到了unordered_map, 但我的编译器不支持使用。
想不借助网络纯靠自己解决,只剩下最后一个方法了,虽然我也不是很想写单链表。

自己想的单链表做法,过了4个样例,另一个超时

#include<iostream>
#include<cstdio>
using namespace std;
struct Node
{
    int i,j,k;
    Node *next;
};
class LinkList
{
public:
    LinkList();//建立只有头结点的单链表
    ~LinkList();
    int Get(int i,int jj);//查找
    void Insert(int ii,int jj,int kk);
private:
    Node *first;
};
LinkList::LinkList()
{
    first=new Node;
    first->next=NULL;
}
LinkList::~LinkList()
{
    Node *p=first;
    while(first!=NULL)
    {
        first=first->next;
        delete p;
        p=first;
    }
}
int LinkList::Get(int ii,int jj)
{
    Node *p=first->next;
    while(p!=NULL)
    {
        if(p->i==ii&&p->j==jj)
            return p->k;
        p=p->next;
    }
    return 0;//用于判断是否找到
}
void LinkList::Insert(int ii,int jj,int kk)
{
    Node *s=NULL;
    s=new Node;
    s->i=ii;
    s->j=jj;
    s->k=kk;
    s->next=first->next;
    first->next=s;
}

int main( )
{
   ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    LinkList L;
    int n,q,a,i,j,k;
    cin>>n>>q;
    while(q--)
    {
        cin>>a>>i>>j;
        if(a==1)
        {
            cin>>k;
            L.Insert(i,j,k);
        }
        else {
            if(L.Get(i,j)!=0)
                cout<<L.Get(i,j)<<endl;
        }
    }
}

map做法,可全AC:

#include<iostream>
#include<map>
using namespace std;

map<int,map<int,int> >p;
int main()
{
    int n,q,a,i,j,k;
    cin>>n>>q;
    while(q--)
    {
        cin>>a>>i>>j;
        if(a==1)
        {
            cin>>k;
            p[i][j]=k;
        }
        else {
            if(p[i][j]!=0)
                cout<<p[i][j]<<endl;
        }
    }
}

学习别人的其他方法,可全AC:原文在这里

#include<iostream>
#include<vector>
using namespace std;
struct jbg
{
    vector<int>l,h;//表示第i个寄包柜每个格子的两个信息,编号j和值h
    int num;//记录第一个第i个寄包柜有几个格子
}d[100005];

int main( )
{
    int n,q,a,i,j,k;
    cin>>n>>q;
    while(q--)
    {
        cin>>a>>i>>j;
        if(a==1)
        {
            cin>>k;
            d[i].num++;//个数加1
            d[i].l.push_back(j);//注意这里的用法,d[i]对应的第i个寄包柜,后面连着vector容器,先存第一个信息j
            d[i].h.push_back(k);//存第二个信息k
        }
        else {
            for(int x=d[i].num-1;x>=0;x--)//循环第i个几包柜下个格子
            {
                if((d[i].l)[x]==j&&(d[i].h)[x]!=0)//注意这里的用法,d[i].l个人把它类似成一个数组的名字(不太确切,只是为了理解),找第一个信息的第x个是否对应为j,第二个信息的第x个是否不是空
                {
                    cout<<(d[i].h)[x]<<endl;
                    break;
                }
            }
        }
    }
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值