这道题是比较简单的输出字符图形的题,但是有几个坑还是要注意下。

1.题中所述的X是大写的,不要看成小写了。(我就错了好几次)

2.每一行输出最后的X后不能在输出空格。

3.输出两个DNA中间有一个空行。

解题思路:

只需要求出一个图形X的排列即可,后边直接重复输出,定义一个数组用来存放X,

注意观察图形,我们们可以知道,X所处的位置有两个情况

1.行列数相同

2.所处行数和列数相加等于总行数加一。

下边是代码:

#include<stdio.h>
int main()
{
 int N;
 scanf("%d",&N);//总的测试实例
 while(N--)
 {
  int a,b,i,j,l;
  scanf("%d %d",&a,&b);
  char c[40][40];//定义字符串。
  for(i=1;i<=a;i++)//a代表行列数,b代表重复次数
  for(j=1;j<=a;j++)
  {
   if(i==j||i+j==a+1)//给字符串赋值 根据排列图中排列的规律
   c[i][j]='X';
   else
   c[i][j]=' ';
  }
  for(i=1;i<=a;i++)//首先输出第一个完整的X排列
  {
        int flag=0;//用标志符号控制是否输出每一行的最后一个X,注意有一行只有一个X
  for(j=1;j<=a;j++)
  {
  if(c[i][j]=='X')
  {
  printf("%c",c[i][j]);
  flag++;
  if(i!=(a+1)/2&&flag==2)//输出最后X后要退出,
  break;
  if(i==(a+1)/2&&flag==1)
  break;
  }
  else
  printf(" ");
     }
  printf("\n");
     }
     for(l=2;l<=b;l++)//下边的输出为数组去掉第一行。
  {
  for(i=2;i<=a;i++)
  {
  int flag=0;
  for(j=1;j<=a;j++)
  {
  if(c[i][j]=='X')
  {
  printf("%c",c[i][j]);
  flag++;
  if(i!=(a+1)/2&&flag==2)
  break;
  if(i==(a+1)/2&&flag==1)
  break;
  }
  else
  printf(" ");
     }
  printf("\n");
  }
     }
  printf("\n");//最后输出结束后输出空行。
 }
 return 0;
}

C语言官网蓝桥杯训练1115DNA的更多相关文章

  1. C语言网 蓝桥杯 1117K-进制数

    这是一道较难的题目,我刚开始用排列组合的方式来做,并没有做出来,故运用了的深搜算法. 深搜算法的概念: 选其中一条路,遍历完成后,逐步返回直至全部遍历,最后返回起点. 解题思路 : 题目中对零的个数没 ...

  2. C语言网蓝桥杯1116 IP判断

    判断IP地址的合法性, 1.不能出现除数字和点字符以外的的其他字符 2.数字必须在0-255之间,要注意边界. 题目分析: 因为一个IP是又四个数字组成,且可能存在符号和其他字符,故不能用整型数组处理 ...

  3. 蓝桥杯训练 2n皇后问题

    给定一个n*n的棋盘,棋盘中有一些位置不能放皇后.现在要向棋盘中放入n个黑皇后和n个白皇后,使任意的两个黑皇后都不在同一行.同一列或同一条对角线上,任意的两个白皇后都不在同一行.同一列或同一条对角线上 ...

  4. 蓝桥杯训练 2n皇后

    问题描述 给定一个n*n的棋盘,棋盘中有一些位置不能放皇后.现在要向棋盘中放入n个黑皇后和n个白皇后,使任意的两个黑皇后都不在同一行.同一列或同一条对角线上,任意的两个白皇后都不在同一行.同一列或同一 ...

  5. 蓝桥杯如何训练?(附VIP题库)

    https://www.dotcpp.com/ 给大家介绍下蓝桥杯,是近几年可以说国内名气最大的程序设计类比赛了 相比国际赛事ACM,蓝桥杯入门简单.中文答题.拿奖率高,更适合国内大众化参加,近几年不 ...

  6. [18/12/3]蓝桥杯 练习系统 入门级别 Fibonacci数列求模问题 题解思路

    前言略. 看到这个题目本来应该很高兴的,因为什么,因为太TM的基础了啊! 可是当你用常规方法尝试提交OJ时你会发现..hhh...运行超时..(开心地摇起了呆毛 //Fibonacci数列递归一般问题 ...

  7. Java实现 蓝桥杯VIP 算法训练 连通分块(并查集)

    试题 算法训练 连通分块 资源限制 时间限制:200ms 内存限制:8.0MB 问题描述 连通分块 输入格式 输入的第一行包含两个整数n, m n代表图中的点的个数,m代表边的个数 接下来m行,每行2 ...

  8. Java实现 蓝桥杯VIP 算法训练 无权最长链

    试题 算法训练 无权最长链 问题描述 给定一个n节点m边的无圈且连通的图,求直径 输入格式 第一行两个数字n,m 接下来m行每行两个数字x,y,代表x,y之间有一条边 输出格式 要求用户的输出满足的格 ...

  9. Java实现 蓝桥杯VIP 算法训练 Car的旅行路线

    大家可以看一下这个,蓝桥杯官网的这道题是有问题的 Car的旅行路线 算法训练 Car的旅行路线 时间限制:1.0s 内存限制:256.0MB 提交此题 锦囊1 锦囊2 查看参考代码 问题描述 又到暑假 ...

随机推荐

  1. 使用PowerDesigner 15对现有数据库进行生成图表结构

    PowerDesigner的安装和基本使用,我就不阐述了.大家可以到这里看看:http://www.blogjava.net/wangdetian168/archive/2011/04/07/Powe ...

  2. linux sort排序及取前几条数据

    查看sort --help -n 根据字符串的数值进行比较 -k 根据某一个关键字的位置或者类型排序 -r 倒序排序 -t 字段分隔,后面跟分隔符 查看head --help -n 打印前几行记录,后 ...

  3. 偶现bug如何处理?

    请先允许我对此类bug进行吐槽,相信做测试的同学都碰见过这种bug! 我们在测试过程中经常会碰见一类很头疼的bug,就是偶现性的bug,所谓偶现性,是相对于必现而言,这类bug有些可以有重现路径,但是 ...

  4. 并发编程-JUC之Atomic

    概述: 早期的JDK版本中,如果要并发的对Integer.Long.Double之类的Java原始类型或引用类型进行操作,一般都需要通过锁来控制并发,以防止数据不一致.JUC-Atomic原子类位于j ...

  5. HTML页面全屏/退出全屏

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. FAST MONTE CARLO ALGORITHMS FOR MATRICES II (快速的矩阵分解策略)

    目录 问题 算法 LINEARTIMESVD 算法 CONSTANTTIMESVD 算法 理论 算法1的理论 算法2 的理论 代码 Drineas P, Kannan R, Mahoney M W, ...

  7. 复杂度定义 The Definition of Complexity

    The upper bound   Big-O: Definition: f(n) is in O(g(n)) if there are constants c0 and N0 such that f ...

  8. xcode8 使用Instruments检测定位并解决iOS内存泄露

    https://www.jianshu.com/p/9bc7e65fc247 2017.07.27 17:24* 字数 628 阅读 1319评论 6喜欢 21 简介: 虽然苹果出了ARC(自动内存管 ...

  9. Sql JOIN 一张图说明

    一图说明:

  10. 其他综合-fdisk一键分区操作-无需脚本

    fdisk一键操作分区-无需脚本(根据自己的实际环境操作) 为了让在系统里能够显示新添加的硬盘已知有两种操作方法 : 1.重启 2.输入echo "- - -" > /sys ...