kkxccy123 2021-09-29 18:02 采纳率: 60%
浏览 129
已结题

c++扑克洗牌的结构体排序😭

完善下列程序,实现对一玩家手中的13张牌按照从小到大排序后输出。

#include <stdio.h>

typedef struct
{ int suit; // 花色 1..4 1~4分别代表梅花,方块,红桃,黑桃
int rank; // 牌点 2..14 其中11~14分别代表J,Q,K,A
} Poker;

void SortCard(Poker cards[], int n)
{ int i,j,p; Poker t;

/*  请在此处补上部分代码,实现程序的功能  */

}

void PrintCard(Poker cards[], int n)
{ char suit[][5]={"","梅花","方块","红桃","黑桃"};
char rank[]="JQKA";
int i;

/*  请在此处补上部分代码,实现程序的功能  */

}

int main()
{ Poker player[13]={ {3,11},{4,3},{2,9},{3,8},{3,14},{1,10},
{1,7},{2,3},{3,6},{1,12},{4,13},{4,6},{2,5}};

printf("发牌后玩家手中的13张牌:\n");
PrintCard(player,13);
SortCard(player,13);
printf("\n理牌后玩家手中的13张牌:\n");
PrintCard(player,13);

getchar();
return 0;

}

  • 写回答

2条回答 默认 最新

  • 关注

    大概这种感觉?

    #include <stdio.h>
    
    typedef struct
    {
        int suit; // 花色 1..4 1~4分别代表梅花,方块,红桃,黑桃
        int rank; // 牌点 2..14 其中11~14分别代表J,Q,K,A
    } Poker;
    int compare(Poker card1, Poker card2)
    {
        if (card1.suit > card2.suit)
        {
            return 1;
        }
        else if (card1.suit < card2.suit)
        {
            return 0;
        }
        else
        {
            if (card1.rank > card2.rank)
                return 1;
            else
                return 0;
        }
    }
    void SortCard(Poker cards[], int n)
    {
        Poker t;
    
        for (int i = 0; i < n - 1; i++)
        {
            for (int j = 0; j < n - 1 - i; j++)
            {
                if (compare(cards[j], cards[j + 1]))
                {
                    t = cards[j + 1];
                    cards[j + 1] = cards[j];
                    cards[j] = t;
                }
            }
        }
    }
    
    void PrintCard(Poker cards[], int n)
    {
        char suit[][5] = {"", "梅花", "方块", "红桃", "黑桃"};
        char rank[] = "JQKA";
    
        for (int i = 0; i < n; i++)
        {
            printf("%s%c\t", suit[cards[i].suit], cards[i].rank > 10 ? rank[cards[i].rank - 11] : (cards[i].rank == 10 ? 'T' : cards[i].rank + '0'));
        }
    }
    
    int main()
    {
        Poker player[13] = {{3, 11}, {4, 3}, {2, 9}, {3, 8}, {3, 14}, {1, 10}, {1, 7}, {2, 3}, {3, 6}, {1, 12}, {4, 13}, {4, 6}, {2, 5}};
    
        printf("发牌后玩家手中的13张牌:\n");
    
        PrintCard(player, 13);
    
        SortCard(player, 13);
    
        printf("\n理牌后玩家手中的13张牌:\n");
    
        PrintCard(player, 13);
    
        // getchar();
    
        return 0;
    }
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 10月7日
  • 已采纳回答 9月29日
  • 创建了问题 9月29日

悬赏问题

  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分