欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C/C++實(shí)現(xiàn)蛇形矩陣的示例代碼

 更新時(shí)間:2022年01月07日 10:04:31   作者:沈⑦今天有敲代碼嘛  
本文主要介紹了C/C++實(shí)現(xiàn)蛇形矩陣的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

菜雞蒟蒻想在博客中記錄一些算法學(xué)習(xí)的心得體會,會持續(xù)更新C/C++方面的題解,方便理清思路和日后復(fù)習(xí)。如果還能結(jié)識一起敲代碼的小伙伴的話就更好啦嘿嘿,因?yàn)閷?shí)在是太弱了,肯定免不了錯(cuò)誤百出。歡迎批評指正,期待共同成長!

題目描述

給出一個(gè)不大于 9 的正整數(shù) n,輸出 n×n 的蛇形方陣。

從左上角填上 1 開始,順時(shí)針方向依次填入數(shù)字,如同樣例所示。注意每個(gè)數(shù)字有都會占用 3 個(gè)字符,前面使用空格補(bǔ)齊。

輸入樣例

輸入

4

輸出

  1  2  3  4
 12 13 14  5
 11 16 15  6
 10  9  8  7

題解部分

涉及算法模擬
各位讀者有聽說過“建模”一詞嗎?所謂“建模”,就是把事物進(jìn)行抽象,根據(jù)實(shí)際問題來建立對應(yīng)的數(shù)學(xué)模型。“抽象”并不意味著晦澀難懂;相反,它提供了大量的便利。計(jì)算機(jī)很難直接去解決實(shí)際問題,但是如果把實(shí)際問題建模成數(shù)學(xué)問題,就會大大地方便計(jì)算機(jī)來“理解”和“解決”。

思路

1.首先我們可以把題目抽象成數(shù)學(xué)問題,題目可以理解成為在一個(gè)方格里按一定規(guī)律填自然數(shù),規(guī)律如下圖。

畫的丑各位輕噴

(畫的丑各位輕噴)
可以看出"小蛇"的走向是右、下、左、上、反復(fù)循環(huán)。

2.建模完畢之后,我們可以把這個(gè)矩陣用二維數(shù)組來表示,每填一個(gè)數(shù)就相當(dāng)于x或者y變化。
注意這個(gè)坐標(biāo)系的建立是根據(jù)二維數(shù)組的特性建立的x代表行、y代表列。

int map[15][15];
//雖然題目要求數(shù)據(jù)最大是9*9,但為了避免內(nèi)存會爆一般會把數(shù)組空間開大一點(diǎn)。
for(i=1;i<=n*n;i++)
map[x][y]=i;

3.那如何控制方向呢?其實(shí)只需要再定義一個(gè)二維數(shù)組就可以啦。

int pos[4][2]={
 		{0,1), //向右填數(shù)
 		{1,0},//向下填數(shù)
 		{0,-1},//向左填數(shù)
 		{-1,0}};//向上填數(shù)

注意順序一定要按小蛇的走向規(guī)律填寫。
為了方便大家理解,可以來看下面這張圖,正好與上面的源碼對應(yīng)。

圖片來源:《啊哈!算法》

通過這個(gè)方向數(shù)組,我們就很容易獲得下一步的坐標(biāo)。這里可以用tx,ty來表示。

int tx=x+t[d][0];
int ty=y+t[d][1];
///通過改變d來改變方向。

4.如何判斷下一步要不要換方向呢?這時(shí),tx,ty就派上用場了。
我們需要判斷tx、ty是否超出邊界,來決定是否轉(zhuǎn)向。

for(i=1;i<=n*n;i++)
{
map[x][y]=i;
tx=x+pos[d][0],ty=y+pos[d][1];
if(tx>n||ty>n||tx<1||ty<1||map[tx][ty]>0)
	d=(d+1)%4;//因?yàn)橹挥兴膫€(gè)方向所以d++時(shí)需要%4,使得d只能是0,1,2,3。
	x=x+pos[d][0],y=y+pos[d][1];//判斷完畢后就可以知道下一步填哪啦。
}

矩陣的大小為n*n,故邊界為[1,n]。
所以一旦tx,ty,超出邊界,就需轉(zhuǎn)向。
需要注意的是遇到之前已經(jīng)填過數(shù)字的方格也需要轉(zhuǎn)向。

ok核心部分已經(jīng)講解完畢,下面奉上完整代碼。

完整代碼

C語言版

#include<stdio.h>
int map[15][15];//需要定義在全局變量,好處是初始化默認(rèn)值都是0。
int pos[4][2]={0,1,1,0,0,-1,-1,0};
int main()
{
	int n;
	int i,j;
	scanf("%d",&n);
	int x=1,y=1,d=0;
	for(i=1;i<=n*n;i++)
	{
		map[x][y]=i;
		int tx=x+pos[d][0],ty=y+pos[d][1];
		if(tx>n||ty>n||tx<1||ty<1||map[tx][ty]>0)
		d=(d+1)%4;
		x=x+pos[d][0],y=y+pos[d][1];
	}
	for(i=1;i<=n;i++)
	{
	for(j=1;j<=n;j++)
	printf("%3d",map[i][j]);
	printf("\n");
	}
	return 0;
}

C++版

#include<bits/stdc++.h>
using namespace std;
int map2[15][15];//因?yàn)閏++類庫太多,定義名為map編譯器會產(chǎn)生歧義,所以在后面加個(gè)2就ok了。
int pos[4][2]={0,1,1,0,0,-1,-1,0};
int main()
{
	int n;
	cin>>n;
	int i,j;
	int x=1,y=1,d=0;
	for(i=1;i<=n*n;i++)
	{
		map2[x][y]=i;
		int tx=x+pos[d][0],ty=y+pos[d][1];
		if(tx>n||ty>n||tx<1||ty<1||map2[tx][ty])
		d=(d+1)%4;
		x=x+pos[d][0],y=y+pos[d][1];
	}
	for(i=1;i<=n;i++)
	{
	for(j=1;j<=n;j++)
	printf("%3d",map2[i][j]);
	cout<<endl;
	}
	return 0;
}

最近剛接觸的c++,不過單從這題來看好像也差不多(捂臉)。

到此這篇關(guān)于C/C++實(shí)現(xiàn)蛇形矩陣的示例代碼的文章就介紹到這了,更多相關(guān)C/C++ 蛇形矩陣內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Linux下C語言實(shí)現(xiàn)貪吃蛇小游戲

    Linux下C語言實(shí)現(xiàn)貪吃蛇小游戲

    這篇文章主要為大家詳細(xì)介紹了Linux下C語言實(shí)現(xiàn)貪吃蛇小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-03-03
  • 使用c語言生成隨機(jī)數(shù)的示例分享

    使用c語言生成隨機(jī)數(shù)的示例分享

    在C語言中,rand()函數(shù)可以用來產(chǎn)生隨機(jī)數(shù),但是這不是真真意義上的隨機(jī)數(shù),是一個(gè)偽隨機(jī)數(shù),這篇文章主要介紹了使用c語言生成隨機(jī)數(shù)的示例,需要的朋友可以參考下
    2014-03-03
  • C語言數(shù)據(jù)結(jié)構(gòu)之 折半查找實(shí)例詳解

    C語言數(shù)據(jù)結(jié)構(gòu)之 折半查找實(shí)例詳解

    這篇文章主要介紹了C語言數(shù)據(jù)結(jié)構(gòu)之 折半查找實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • c語言分離三位數(shù)的實(shí)現(xiàn)

    c語言分離三位數(shù)的實(shí)現(xiàn)

    這篇文章主要介紹了c語言分離三位數(shù)的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • C++中的偽隨機(jī)數(shù)

    C++中的偽隨機(jī)數(shù)

    這篇文章主要介紹了C++中的偽隨機(jī)數(shù),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • C語言 風(fēng)靡一時(shí)的黃金礦工游戲?qū)崿F(xiàn)流程詳解

    C語言 風(fēng)靡一時(shí)的黃金礦工游戲?qū)崿F(xiàn)流程詳解

    《黃金礦工》是一款非常經(jīng)典的游戲。在游戲中,玩家通過不斷挖礦,獲取金子,最終能夠闖入下一關(guān)。在這個(gè)過程中,會不斷有巖石、煙霧、老鼠來搗亂,甚至還會出現(xiàn)扛著炸藥包的小老鼠,玩家必須戰(zhàn)勝它們,才能進(jìn)入更深的礦坑
    2021-11-11
  • VC++實(shí)現(xiàn)文件與應(yīng)用程序關(guān)聯(lián)的方法(注冊表修改)

    VC++實(shí)現(xiàn)文件與應(yīng)用程序關(guān)聯(lián)的方法(注冊表修改)

    這篇文章主要介紹了VC++實(shí)現(xiàn)文件與應(yīng)用程序關(guān)聯(lián)的方法,涉及VC++針對注冊表的相關(guān)操作技巧,需要的朋友可以參考下
    2016-08-08
  • 深度解析C語言中數(shù)據(jù)的存儲

    深度解析C語言中數(shù)據(jù)的存儲

    本文詳細(xì)介紹了C語言中數(shù)據(jù)的存儲,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • C++利用jsoncpp庫實(shí)現(xiàn)寫入和讀取json文件

    C++利用jsoncpp庫實(shí)現(xiàn)寫入和讀取json文件

    JsonCpp 是一個(gè)C++庫,允許操作 JSON 值,包括序列化和反序列化到字符串和從字符串反序列化。本文主要介紹了如何利用jsoncpp庫實(shí)現(xiàn)寫入和讀取json文件,感興趣的可以了解一下
    2023-04-04
  • C語言實(shí)現(xiàn)24點(diǎn)游戲源代碼

    C語言實(shí)現(xiàn)24點(diǎn)游戲源代碼

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)24點(diǎn)游戲源代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10

最新評論