| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 922 人关注过本帖
标题:[求助]介绍个思想
只看楼主 加入收藏
中华武者
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2007-5-19
收藏
得分:0 
不错
2007-05-22 16:57
kyq60802
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2007-5-20
收藏
得分:0 

[QUOTE]#include<iostream>
#include<iomanip>
using namespace std;
void main()//运行环境VC6.0++(测试通过)

{
const int N = 4;//由于本人还没有学动态数组,所以只能这样了,可以改下这个值:5,6,7……
int i = 0, j = 0;

int count = 1;
int Array[N][N];
bool up = true;

for (;i + j < 2*N - 2;) //控制数据的移动
{
if (count == 1)
{}
else
if (up)//上移
{
Array[i++][j--] = count++;
for (;i >= 0 && i < N - 1 && j > 0 && j < N - 1;)
{
Array[i++][j--] = count++;
}
}
else//下移
{
Array[i--][j++] = count++;
for (;i > 0 && i < N - 1 && j >= 0 && j < N - 1;)
{
Array[i--][j++] = count++;
}
}

if ((j == 0 && i != N - 1) || j == N - 1)//边缘情况
{
Array[i++][j] = count++;
up = !up;

}
else
{
Array[i][j++] = count++;
up = !up;
}
Array[i][j] = count;
}
for (i = 0;i < N;i++)//打印
{
for (j = 0;j < N;j++)
{
cout << setw(4) << Array[i][j];
}
cout << endl;
}

}

[/QUOTE]
不知道你是什么思路
勉强可以看懂
但让我再写,我还是写不出来
不知道你是用什么思路
谢谢赐教
2007-05-22 22:54
kyq60802
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2007-5-20
收藏
得分:0 
以下是引用aipb2007在2007-5-22 13:21:22的发言:

[CODE]#include <iostream>
using namespace std;
const int n = 4;
int main(){
int a[n][n];
int i = 0,j = 0,k = 1;
bool right_up = false;

while (k != n*n+1){
if (right_up){
for (;i >= 0 && j < n;--i,++j)
a[i][j] = k++;
right_up = false;
j == n ? --j,i+=2 : ++i;
}
else{
for (;j >= 0 && i < n;++i,--j)
a[i][j] = k++;
right_up = true;
i == n ? --i,j+=2 : ++j;
}
}
//display :
for (int i = 0;i < n;++i){
for (int j = 0;j < n;++j)
cout << a[i][j] << " ";
cout << endl;
}
system("pause");
}[/CODE]

写了哈!

在vc6.0
不能运行

2007-05-22 22:56
kyq60802
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2007-5-20
收藏
得分:0 
#include <iostream.h>
const int n = 4;
void main(){
int a[n][n];
int i = 0,j = 0,k = 1;
bool right_up = false;

while (k != n*n+1){
if (right_up){
for (;i >= 0 && j < n;--i,++j)
a[i][j] = k++;
right_up = false;
j == n ? --j,i+=2 : ++i;
}
else{
for (;j >= 0 && i < n;++i,--j)
a[i][j] = k++;
right_up = true;
i == n ? --i,j+=2 : ++j;
}
}
for (i = 0;i < n;++i){
for (int j = 0;j < n;++j)
cout << a[i][j] << " ";
cout << endl;
}
return;
}

谢谢,可以了
2007-05-22 22:59
孤魂居士
Rank: 2
来 自:老A(中国地大)
等 级:论坛游民
威 望:4
帖 子:1142
专家分:18
注 册:2007-5-21
收藏
得分:0 
晕``你是不是瞎用键盘打的一个数组啊``
上面的的兄弟太强了
什么数组规律都想的出来```牛B

准备用3年做个高级软件工程师 10年也做不成。准备用10年做成高级软件工程师 3年就成了QQ 群 45771086
欢迎版主...欢迎JAVA爱好者...
一起从深夜 到凌晨...
2007-05-22 23:09
aipb2007
Rank: 8Rank: 8
来 自:CQU
等 级:贵宾
威 望:40
帖 子:2879
专家分:7
注 册:2007-3-18
收藏
得分:0 
回复:(kyq60802)#include const...
在vc6.0不能报错i重定义了吧?

这可不是我的错,是vc6.0对标准的支持问题!i的作用域是语句作用域,是可以这样用的!

Fight  to win  or  die...
2007-05-23 09:20
快速回复:[求助]介绍个思想
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.029242 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved