#include<bits/stdc++.h>
using namespace std;
bool state[7][7];//布尔数组,且初始都为零,第一层是那个股子,第二层是该股子具体哪个数是否已经出现过
int main()
{
int a[7];//股子大小
int n;
for(int i=1;i<=6;i++)
{
cin>>a[i];
state[i][a[i]]=1;//第一次输入的都设置为已经出现过
}cin>>n;
for(int j=1;j<=6;j++)//6个股子循环
{
for(int i=0;i<n;i++)//进行次数
{
for(int k=6;k>=1;k--)//每次进行都要6开始查是否出现过,因为倘若第一次不是六,那么第二次一定是六,第三次就是递减
{
if(state[j][k]==0){a[j]=k;state[j][k]=1;break;}
}
}
if(j<6)cout<<a[j]<<" ";
else cout<<a[j];//注意题目要求,不能够有多余的空格
}
}
难度在于读懂题目
倘若第一次股子数不是六,那么第二次一定是六,第三次就开始从六递减