1) 下面代码有哪些错误?(台湾某公司05年12月笔试题)
#include <iostream>
using namespace std;

int main()


{
int &t1;
int *pi;
*pi = 3;
const double dt;
cout<<pi<<endl;
return 0;
}

答案#region 答案
1 引用不能为空,必须在定义时同时初始化
2 声明了一个整型指针,但没有指向实际的地址,因此赋值的操作为出错
3 常量定义时应该同时初始化
#endregion

2)下面是一个蛇型矩阵
21 22 23。。。
20 7 8 9 10
19 6 1 2 11
18 5 4 3 12
17 16 15 14 13
设1点的坐标为(0,0),X方向向右为正,y方向向下为正,如:7的坐标为(-1,-1),2的坐标为(0,1),编程实现输入任意一坐标(x,y),输出所对应的数.(诺基亚05年笔试题).
#include <iostream>
#include <cstdlib>
#include <algorithm>

using namespace std;

const int N = 100;

int data[N + 1][N + 1];

enum DIRECTION


{
RIGHT, DOWN , LEFT, UP
};

//模拟整个过程
void Simulate(int n)


{
int x, y;
x = y = (n - 1) / 2; //1的位置
data[x][y] = 1;
int len = 1;
int count = 0;
int num = 2;
DIRECTION dir = RIGHT;
while(num <= n * n)

{
for(int i = 0; i < len; i++)

{
switch(dir)

{
case LEFT:
--y; break;
case RIGHT:
++y; break;
case UP:
--x; break;
case DOWN:
++x; break;
default: break;
}
data[x][y] = num++;
}
count++;
if(count == 2)

{
count = 0;
len++;
}
dir = (DIRECTION)((dir + 1) % 4);
}
}

//打印螺旋矩阵
void Output(int n)


{
int i, j;
for(i = 0; i < n; i++)

{
cout << data[i][0];
for(j = 1; j < n; j++)
cout << "\t" << data[i][j];
cout << endl;
}
}

//以(1,1)所在位置作为原点,向右作为x正半轴,向下作为y正半轴
int GetValue(int x, int y)


{
int m = max(abs(x), abs(y));
int rightBottom = m * m * 4 - 2 * m + 1;
int value = 0;
if(x == -m)

{
value = rightBottom + 2 * m + m - y;
}
else if( y == m)

{
value = rightBottom + m - x;
}
else if(y == -m)

{
value = rightBottom + 4 * m + x + m;
}
else if( x == m )

{
value = rightBottom - (m - y);
}

return value;
}

void TestPos(int n)


{
int i, j;
for(i = 0; i < n; i++)

{
cout << GetValue(0 - (n - 1) / 2, i - (n - 1) / 2);
for(j = 1; j < n; j++)
cout << "\t" << GetValue(j - (n - 1) / 2, i - (n - 1) / 2);
cout << endl;
}
}

int main()


{
int n;
while(cin >> n)

{
if(n <= 0 || n > 100)

{
cerr << "Size error!" << endl;
break;
}
else

{
Simulate(n);
Output(n);
cout << "*******************" << endl;
TestPos(n);
}
}

return 0;
}

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述