#include <iostream>
#include <cstdio>
#include <algorithm>
#include <set>
#include <string>
#include <sstream>
#include <vector>
#include <map>
using namespace std;
int main()
{
//freopen("c:\\test.txt","r",stdin);
//freopen("c:\\h.txt","w",stdout);
vector<int> card;
int n;
while(cin>>n&&n)
{
int cnt=0;
for(int i=0;i<n;i++)
card.push_back(i+1);
if(n==1)
cout<<"Discarded cards:";
else
cout<<"Discarded cards: ";
for(vector<int>::size_type i=card.size();i>1;i--) //当牌数大于1张的时候
{
if(card.size()>2)
cout<<*card.begin()<<", ";
else
cout<<*card.begin(); //输出第一张
card.erase(card.begin()); //删除第一张
int temp=*card.begin(); //记录此时第一张牌(就是原来牌堆的第二张)
card.push_back(temp); //加到vector最后
card.erase(card.begin()); //删除第一张(就是原来牌堆的第二张放到最后)
}
cout<<endl;
cout<<"Remaining card: "<<*card.begin()<<endl; //输出最后一张(最后剩下的一张)
card.clear();
}
return 0;
}
本文介绍了一个简单的纸牌游戏算法实现过程,通过C++代码展示了如何进行纸牌的弃牌和保留操作,直到最终只剩下一张牌。代码使用了vector容器来存储牌组,并通过迭代移除和重新排列元素实现了游戏逻辑。
454

被折叠的 条评论
为什么被折叠?



