IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> PAT A1042 -> 正文阅读

[开发测试]PAT A1042

在这里插入图片描述在这里插入图片描述

方法一:借鉴别人的,满分通过版本

#include<stdio.h>
const int N = 54;
char mp[5] = { 'S', 'H', 'C', 'D', 'J'};
int start[N+1], end[N+1], next[N+1];
int main()
{
    int K;
    scanf("%d", &K);
    for(int i = 1; i <= N; i++)
    {
        start[i] = i;//初始化牌的编号
    }
    for(int i = 1; i <= N; i++)
    {
        scanf("%d", &next[i]);//操作后牌的位置
    }
    for(int step = 0; step < K; step++)
    {
        for(int i = 1; i <=N; i++)
        {
            end[next[i]] = start[i];//i位置的牌存在next[i]
        }
        for(int i = 1; i <= N; i++)
        {
            start[i] = end[i];//非常有用的一步
        }
    }
    for(int i = 1; i<= N; i++)
    {
        if(i != 1) printf(" ");//控制格式
        start[i]--;
        printf("%c%d",mp[start[i] / 13] , start[i] % 13 + 1);
    }
    return 0;
}

方法二:输出结果与答案完全一致,但是所有测试用例均显示答案错误,可能是每次循环都输出了’\0’的缘故。

#include<cstdio>

const int CARDS = 54;
int a[60] = {0};//存放洗牌顺序 
int b[2][60] = {0};//存放每次洗牌后的位置 

char * getCard(int a){
	char c[4];
	char * result = c; 
	switch((a - 1) / 13){
		case 0:c[0] = 'S';break;
		case 1:c[0] = 'H';break;
		case 2:c[0] = 'C';break;
		case 3:c[0] = 'D';break;
		case 4:c[0] = 'J';break;
	}
	int num = (a - 1) % 13 + 1;
	if(num >= 10){
		c[1] = '1';
		c[2] = num - 10 + '0';
		c[3] = '\0';
	}else{
		c[1] =  num + '0';
		c[2] = '\0';
	}
	return result;
}
int main(){
	
	int k;
	scanf("%d",&k);
	for(int i = 1; i <= CARDS; i++){
		scanf("%d",&a[i]);
	}
	for(int i = 0;i < k; i++){
		if(i == 0){
			for(int i = 1; i <= CARDS; i++){
				b[0][a[i]] = i;
			}
		} else{
			if(i % 2 == 0){
				for(int i = 1; i <= CARDS; i++){
					b[0][a[i]] = b[1][i];
				}
			}else{
				for(int i = 1; i <= CARDS; i++){
					b[1][a[i]] = b[0][i];
				}
			}
		}
	}
	for(int i = 1; i <= CARDS; i++){
		if(i != 1){
			printf(" ");
		}
		printf("%s",getCard(b[1 - k % 2][i]));
	} 
	return 0;
}

方法三:在方法二的基础上结合方法一最后的处理,满分通过

#include<cstdio>

const int CARDS = 54;
int a[60] = {0};//存放洗牌顺序 
int b[2][60] = {0};//存放每次洗牌后的位置 
char mp[5] = { 'S', 'H', 'C', 'D', 'J'};
char * getCard(int a){
	char c[4];
	char * result = c; 
	switch((a - 1) / 13){
		case 0:c[0] = 'S';break;
		case 1:c[0] = 'H';break;
		case 2:c[0] = 'C';break;
		case 3:c[0] = 'D';break;
		case 4:c[0] = 'J';break;
	}
	int num = (a - 1) % 13 + 1;
	if(num >= 10){
		c[1] = '1';
		c[2] = num - 10 + '0';
		c[3] = '\0';
	}else{
		c[1] =  num + '0';
		c[2] = '\0';
	}
	return result;
}
int main(){
	
	int k;
	scanf("%d",&k);
	for(int i = 1; i <= CARDS; i++){
		scanf("%d",&a[i]);
	}
	for(int i = 0;i < k; i++){
		if(i == 0){
			for(int i = 1; i <= CARDS; i++){
				b[0][a[i]] = i;
			}
		} else{
			if(i % 2 == 0){
				for(int i = 1; i <= CARDS; i++){
					b[0][a[i]] = b[1][i];
				}
			}else{
				for(int i = 1; i <= CARDS; i++){
					b[1][a[i]] = b[0][i];
				}
			}
		}
	}
	for(int i = 1; i <= CARDS; i++){
		if(i != 1){
			printf(" ");
		}
		int index = b[1 - k % 2][i];
		printf("%c%d",mp[(index - 1)/13],(index - 1)%13+1);
	} 
	return 0;
}

  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2021-07-04 20:02:21  更:2021-07-04 20:02:51 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/17 18:41:13-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码