首页 > 其他分享 >牛客 空心正方形,X形图案(c)

牛客 空心正方形,X形图案(c)

时间:2024-09-10 18:52:37浏览次数:13  
标签:输出 正方形 示例 int 空心 图案 牛客 输入

 空心正方形

题目

KiKi学习了循环,BoBo老师给他出了一系列打印图案的练习,该任务是打印用“*”组成的“空心”正方形图案。

示例

输入:

4

输出:
* * * * 
*     * 
*     * 
* * * * 

题目链接

空心正方形图案_牛客题霸_牛客网

思路

我们只需要将第一行和最后一行,第一列和最后一列输出*即可,其余位置输出空格。

代码:

#include <stdio.h>

int main() {
	int n;
	while (scanf("%d", &n) != EOF) {
		if (n >= 3 && n <= 20) {
			for (int i = 0; i < n; i++) {
				if (i == 0 || i == n-1) {//输出第一行和最后一行的*
					for (int j = 0; j < n; j++) {
						printf("* ");
					}
				}
				else {
					for (int j = 0; j < n; j++) {
						if (j == 0 || j == n-1) {//输出第一列和最后一列的*
							printf("* ");
						}
						else//其余位置输出空格
							printf("  ");
					}
				}
				printf("\n");
			}
		}
	}
	return 0;
}

 X形图案

题目

KiKi学习了循环,BoBo老师给他出了一系列打印图案的练习,该任务是打印用“*”组成的X形图案。

示例1

输入:

6

输出:

*    *
 *  * 
  **  
  **  
 *  * 
*    *

示例2

输入

5

输出

*   *
 * * 
  *  
 * * 
*   *

题目链接

X形图案_牛客题霸_牛客网

思路

通过观察示例,我们发现输入的数字是奇数时,图案最中间只有一个*,其余行均输出两个*。而若输入的数字为偶数时,图案最中间两行排列一样,且都是输出两个*。输入的数字等于输出的行数和列数,即使用两个for循环搞定,关键是图案每行都输出两个‘*’字符(除输入奇数时的最中间一行为一个‘*’),其余均用空格字符输出。

我们发现输出时*的位置是第i行的第i个和第a-i-1个。

代码:

#include <stdio.h>  

int main() {
	int a = 0;
	while (scanf("%d", &a) != EOF) {
		if ((a >= 2) && (a <= 20)) {
			for (int i = 0; i < a; i++) {
				// 移除了内层 for 循环中对 j 的重新声明  
				for (int j = 0; j < a; j++) {
					if ((j == i) || (j == (a - i - 1))) {
						printf("*");
					}
					else {
						printf(" ");
					}
				}
				// 每完成一行的打印后换行  
				printf("\n");
			}
		}
	}
	return 0;
}

祝大家生活愉快。

标签:输出,正方形,示例,int,空心,图案,牛客,输入
From: https://blog.csdn.net/2303_80645930/article/details/141996183

相关文章

  • 每日OJ_牛客_单词倒排(字符串模拟)
    目录牛客_单词倒排(字符串模拟)解析代码牛客_单词倒排(字符串模拟)单词倒排__牛客网时间限制:C/C++1秒,其他语言2秒空间限制:C/C++32M,其他语言64M题目描述:对字符串中的所有单词进行倒排。说明:1、构成单词的字符只有26个大写或小写英文字母;2、非构成单词的字符均视为单词......
  • 牛客小白月赛100
    A-ACM中的A题#include<bits/stdc++.h>usingnamespacestd;usingi32=int32_t;usingi64=longlong;#defineinti64usingvi=vector<int>;constintN=10;chars[N];i32main(){inta,b,c;cin>>a>>b>>......
  • 牛客周赛 Round 59(下)
    逆序数题目描述登录—专业IT笔试面试备考平台_牛客网运行代码#include<bits/stdc++.h>usingnamespacestd;typedeflonglongll;intmain(){lln,k;cin>>n>>k;llsum=(n*(n-1))/2;cout<<sum-k<<endl;return0;}代码思路组合数的计算:在......
  • 每日OJ_牛客_骆驼命名法(递归深搜)
    目录牛客_骆驼命名法(简单模拟)解析代码牛客_骆驼命名法(简单模拟)骆驼命名法__牛客网解析代码首先一个字符一个字符的读取内容:遇到_就直接跳过。如果上一个字符是_则下一个字符转大写字母。#include<iostream>#include<string>usingnamespacestd;intmai......
  • 牛客网测试题 把十六进制数字转换为十进制数字
    1/**2*把十六进制数字转换为十进制数字3*@paramhexSrcStr4*@return5*1706*/7publicstaticStringconvertHex2Decimal(StringhexSrcStr){8if(hexSrcStr==null||hexSrcStr.trim().length()==0){9returnnull;10}11......
  • ACM中的AC题(BFS,三维vis,牛客小白月赛)
    题目来源:https://ac.nowcoder.com/acm/contest/88878/D//题意:迷宫中,两个人,走的每一步两个人的方向都是相反的,问两个人都走到地图中‘@’,最少的步数(地图上多个‘@’)。//思路:难点就在可以一个人到了,然后另一个人再独自走,就不用考虑到了那个人了。说明一个人独自走是可能会走重复......
  • 每日OJ_牛客_最长递增子序列(dp/贪心模板)
    目录牛客_最长递增子序列(dp/贪心模板)解析代码牛客_最长递增子序列(dp/贪心模板)最长公共子序列__牛客网解析代码在一个序列中找最长递增子序列,动态规划的典型应用,下面是两个模版CISdp模板:#include<iostream>#include<vector>usingnamespacestd;intLIS(vect......
  • 每日OJ_牛客_最长公共子序列(dp模板)
    目录牛客_最长公共子序列(dp模板)解析代码牛客_最长公共子序列(dp模板)最长公共子序列__牛客网解析代码子序列即两个字符串中公共的字符,但不一定连续。        从题干中可以提取出问题:求字符串s和t的最长公共子序列假设LCS(m,n)为长度为m的字符串s与长度为n的......
  • 洛谷题单指南-常见优化技巧-P2216 [HAOI2007] 理想的正方形
    原题链接:https://www.luogu.com.cn/problem/P2216题意解读:在矩阵中找n*n正方形里最大值和最小值差值的最小值。解题思路:1、枚举法直接枚举所有n*n的正方形的位置,然后在遍历求最大值、最小值,复杂度为O(n^4),显然不能通过。2、二维单调队列既然是求正方形范围内的最值,看起来是......
  • 【牛客网】JZ65:不用四则运算符实现两数相加
    文章目录问题来源思考例:使用位操作符进行int变量交换位操作符的使用代码实现问题来源牛客网数据结构题目......