zoukankan      html  css  js  c++  java
  • UVA

    题目大意

    桌上有一叠牌,自上而下编号为1~n。若桌上牌数大于1张,那么丢弃一张顶部牌后,再将现在的顶部牌移到最后。要求给出模拟过程和最终剩余的牌号

    思路分析

    典型队列模拟,丢弃即出队,移到最后即入队,但队列大小为1时停止操作

    注意点

    • 注意n=1时特例,Discarded cards:后无需空格
    #include<bits/stdc++.h>
    using namespace std;
    int n;
    int main() {
        while (cin >>n && n != 0) {
            printf("Discarded cards:");
            queue<int> q;
            for (int i = 1; i <= n; i ++) q.push(i);
            while (q.size() != 1) {
                printf("%s%d", q.front() == 1 ? " " : ", ", q.front()); // 第一个退出无输出,
                q.pop();
                q.push(q.front()); q.pop(); // 头入队后删除
            }
            printf("
    Remaining card: %d
    ", q.front());
        }
        return 0;
    }
    
  • 相关阅读:
    9.16第一次上课关于HTML的小结
    9.22课堂记录
    9.19课堂记录
    html文档基本结构
    HTMl学习1
    HTML第一次学习笔记
    CSS3和CSS2.1的区别
    HTML5新元素
    第一课:HTML
    块级元素和行内元素
  • 原文地址:https://www.cnblogs.com/RioTian/p/13027955.html
Copyright © 2011-2022 走看看