日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

猫狗收养所问题(指针模拟)

發(fā)布時(shí)間:2025/4/16 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 猫狗收养所问题(指针模拟) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

用int型作為指針實(shí)現(xiàn)
貓狗收養(yǎng)所,只有貓和狗
第一個(gè)數(shù)是1表示是在輸入
* 操作數(shù)如果是整數(shù),表示是狗的編號(hào)
* 操作數(shù)如果是負(fù)數(shù),表示是貓的編號(hào)

第二個(gè)數(shù)是2表示被領(lǐng)走
* 操作數(shù)如果是0,表示領(lǐng)走所有貓狗中最先進(jìn)來(lái)的那個(gè)
* 操作數(shù)是1,表示領(lǐng)走狗中最先進(jìn)來(lái)的那個(gè)
* 操作數(shù)是-1,表示領(lǐng)走貓中最先進(jìn)來(lái)的那個(gè)
輸入一堆操作
按照順序輸出被領(lǐng)走的小動(dòng)物的編號(hào)

#include <vector> #include <iostream> using namespace std; vector< pair<int,int> > v,store; int dogreflesh(){ //return the first dogfor (int i = 0; i < v.size(); ++i) {if (v[i].second > 0) {return i;}}return -1; } int catreflesh(){for (int i = 0; i < v.size(); ++i) {if (v[i].second < 0) {return i;}}return -1; } int main(){int dog, cat;dog = cat = -1;int oper, open;while (cin >> oper >> open) {if (oper == 1) {if (open == 0) {continue;} else if (open > 0){dog = v.size() - 1;} else {cat = v.size() - 1;}v.push_back({oper, open});} else if (oper == 2){if (open == 0 && v.size() > 0) {store.push_back(v[0]);v.erase(v.begin());dog = dogreflesh();cat = catreflesh();} else if (open == 1 && dog >= 0) {store.push_back(v[dog]);v.erase(v.begin() + dog);dog = dogreflesh();} else if (open == -1 && cat >= 0) {store.push_back(v[cat]);v.erase(v.begin() + cat);cat = catreflesh();}}} for (int i = 0; i < store.size(); ++i) {cout << store[i].second<<" ";} }

下面是測(cè)試輸入數(shù)據(jù)

1 1 1 -1 2 0 2 -1

輸入結(jié)果是 1, -1

總結(jié)

以上是生活随笔為你收集整理的猫狗收养所问题(指针模拟)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。