当前位置:   article > 正文

C++之顺序表:为啥你写的代码有脏数据?_c语言脏数据

c语言脏数据

1.如果对于一个顺序表在初始化的时候不给他赋值初始化,他将会变得一发不可收拾.jpg
现在声明一个线性表(顺序表),并且初始化其长度,但并未赋初值,会有什么后果呢?

#include<stdio.h>
#define MaxSize 10
typedef struct {
	int data[MaxSize];
	int length;//表长
}SqList;

void InitList(SqList& L) {
	/*
	//赋初值,可省略,但会产生"脏数据"
	for(int i=0;i<MaxSize;i++)
	L.data[i] = 0;
	*/

	L.length = 0;//空表
}
int main()
{
	SqList L;
	InitList(L);
	//不严谨访问元素的写法
	for (int i = 0; i < MaxSize; i++)
	{
		printf("data[%d]=%d\n", i, L.data[i]);
	}	return 0;
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27

运行结果如下:(脏数据产生了
在这里插入图片描述
2.正确做法是在初始化顺序表的同时,依次给它赋初值,则不会产生“脏数据”了。

#include<stdio.h>
#define MaxSize 10
typedef struct {
	int data[MaxSize];
	int length;//表长
}SqList;

void InitList(SqList& L) {
	
	//赋初值,可省略,但会产生"脏数据"
	for(int i=0;i<MaxSize;i++)
	L.data[i] = 0;
	L.length = 0;//空表
}
int main()
{
	SqList L;
	InitList(L);
	//不严谨访问元素的写法
	for (int i = 0; i < MaxSize; i++)
	{
		printf("data[%d]=%d\n", i, L.data[i]);
	}	return 0;
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25

在这里插入图片描述

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/512186
推荐阅读
相关标签
  

闽ICP备14008679号