DS题目汇编

一、

二、表2-8洗盘子

代码

cpp 复制代码
#include <stdio.h>
# define MAXSIZE 50005
int pigs[MAXSIZE];
int lucky_pigs[3005];
void find_luck(){
    int n=0;
    for(int i=2;i<MAXSIZE;i++) pigs[n++]=i;
    int cnt=0;
    while(cnt<=3000){
        int head=pigs[0];
        lucky_pigs[cnt++]=head;
        int newn=0;
        int pos=0;
        for(int i=1;i<n;i++){
            pos++;
            //删除位置满足pos % head == 0。
            if(pos%head!=0){
                pigs[newn++]=pigs[i];//把没被删除的元素往前挪 
            }
        }
        n=newn;
    }
}
int main(){
    int t,x;
    find_luck();
    scanf("%d",&t);
    while(t--){
        scanf("%d",&x);
        printf("%d\n",lucky_pigs[x-1]);
    }
    return 0;
}
相关推荐
byxdaz4 小时前
C++内存序
c++
优雅的潮叭4 小时前
c++ 学习笔记之 malloc
c++·笔记·学习
苦藤新鸡6 小时前
8.最长的无重复字符的子串
c++·力扣
꧁Q༒ོγ꧂7 小时前
C++ 入门完全指南(四)--函数与模块化编程
开发语言·c++
汉克老师7 小时前
GESP2025年12月认证C++八级真题与解析(判断题8-10)
c++·快速排序··lcs·gesp八级·gesp8级
qq_433554547 小时前
C++ manacher(求解回文串问题)
开发语言·c++·算法
HL_风神8 小时前
设计原则之迪米特
c++·学习·设计模式
HL_风神8 小时前
设计原则之合成复用
c++·学习·设计模式
汉克老师9 小时前
GESP2025年12月认证C++八级真题与解析(单选题10-12)
c++·递归··gesp八级·gesp8级
bkspiderx10 小时前
C++中的map容器:键值对的有序管理与高效检索
开发语言·c++·stl·map