栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

C语言解决洗牌问题

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C语言解决洗牌问题

此问题的关键是要建立多个数组并且层层嵌套

#include

#include

void shuffling (int a[],int b[],int c[],int x);

void printit (int num[],char word[]);

void copye(int a[],int b[]);

int main(){

    char word[5] = {'S','H','C','D','J'};

    int i = 0,x = 0,u = 0;

    int n;

    int num[54];

    int copy[54];

    int init[54];

    scanf("%d",&n);

    for(i ; i < 54 ; i++){

        num[i] = i+1;

        scanf("%d",&init[i]);

    }

    copye(copy,num);

    for(;1;){

    for(i=0 ;i < 54;i++){

        shuffling(num,copy,init,i);

        x++;

    }

    u++;

    copye(copy,num);

    if (u == n)

    break;

    }

    printit (num,word);

    system("pause");

    return 0;

}

void shuffling (int a[],int b[],int c[],int x){

   

    a[c[x] - 1] = b[x];

}

void printit (int num[],char word[]){

    int i = 0;

    for (i ; i < 54; i++){

        if(num[i]%13 != 0)

        printf("%c%d",word[num[i]/13],num[i]%13);

        else

        printf("%c13",word[num[i]/13 -1]);

        if(i < 53)

        printf(" ");

    }

}

void copye(int a[],int b[]){

    int i = 0;

    for (i ; i < 54 ; i++){

        a[i]=b[i];

    }

}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/850038.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号