二维数组中什么是按行存储?c语言中二维数组按行还是按列存储啊

seosqwseo3周前 (04-20)测评日记11

一、什么是一维数组

数组是一个由若干同类型变量组成的**,引用这些变量时可用同一名字。数组均由连续的存储单元组成,低地址对应于数组的第一个元素,高地址对应于后一个元素,数组可以是一维的,也可以是多维的。

5.1一维数组

一维数组的一般说明形式如下:

type-specifier var_name [size];

在C语言中,数组必须显示地说明,以便编译程序为它们分配内存空间。在上式中,类型说明符指明数组的类型,也就是数组中每一个元素个数,一维数组的总字节数可按下式计算:

sizeof(类型)*数组长度=总字节数

[例5-1]将数字0到9装入一个整型数组。

main()

{

int x[10];/*定义包含1 0个整型数的数组,引用为x [ 0 ],x [ 1 ]... x [ 9 ]*/

int t;

for(t=0; t<10;++t) x[t]=t;

}

C语言并不检验数组边界,因此,数组的两端都有可能越界而使其它变量的数组甚至程序代码被破坏。在需要的时候,数组的边界检验便是程序员的职责。例如,当使用gets()接收字符输入时,必须确认字符数组的长度足以存放长的字符串。

一维数组在本质上是由同类数据构成的表,例如,对下列数组a:

char a[7]

图5- 1说明了数组a在内存中的情形,假定起始地址为1000。

5.1.1向函数传递一维数组

将一维数组传递给函数时,把数组名作为参数直接调用函数即可,无需任何下标。这样,数组的第一个元素的地址将传递给该函数。C语言并不是将整个数组作为实参来传递,而是用指针来代替它。例如,下面的程序将数组i的第一个元素的地址传递给函数func1()。

main()

{

int i[10];

func1(i);/*函数调用,实参是数组名*/

...

}

函数若要接收一维数组的传递,则可以用下面的二种方法之一来说明形式参数; 1)有界数组;2)**数组。例如,函数func1()要接收数组i可如下说明:

func1(str)

char str[10];/*有界数组,数组的下标只能小于或等于传递数组的大小。*/

{

.

..

}

也可说明为:

func1(str)

char str[ ];/***数组*/

{

.

..

}

这二种说明方法的效果是等价的,它们都通知编译程序建立一个字符指针。第一种说明使用的是标准的数组说明;后一种说明使用了改进型的数组说明,它只是说明函数将要接收一个具有一定长度的整型数组。细想就会发现,就函数而言,数组究竟有多长并无关紧要,因为C语言并不进行数组的边界检验。事实上,就编译程序而言,下面的说明也是可行的。

func1(str);

int str[32];

{

...

}

因为编译程序只是产生代码使函数func1()接收一个指针,并非真正产生一个包含3 2个元素的数组。

5.1.2字符串使用的一维数组

显然,一维数组的普通的用法是作为字符串。在C语言中,字符串被定义为一个以空字符终结的字符数组。空字符以‘\ 0’来标识,它通常是不显示的。因此,在说明字符数组时,必须比它要存放的长字符串多一个字符。例如,假如要定义一个存放长度为1 0的字符串的数组s,可以写成:

char s[11];

这样就给字符串末尾的空字符保留了空间。

尽管C语言并不把字符串定义为一种数据类型,但却允许使用字符串常量。字符串常量是由双引号括起来的字符表。例如,下面两个短语均为字符串常量:

"hello there"

"this is a test"

不必向字符串的末尾加空字符, C编译程序会自动完成这一工作。

C语言支持多串*作函数,常用的有:

名字功能

strcpy(s1 s2)将s2拷贝到s1

strcat(s1 s2)将s 2连接到s 1的末尾

strlen(s1)返回s1的长度

strcmp(s1,s2)若s1与s2相等,返回值为0

若s1< s2,返回值小于0

若s1> s2,返回值大于0

例5- 2说明了这些函数的用法。

[例5- 2 ]

#include<stdio.h>

main()

{

char s1[80],s2[80];/*定义字符数组*/

gets(s1);/*输入字符串*/

gets(s2);

printf("lengthsf:%d%d\n",strlen(s1),strlen(s2));

if(!strcmp(s1,s2))

printf("the strings are equal\n");

strcat(s1,s2);

printf("%s\n",s1);

}

切记,当两个串相等时,函数strcmp()将返回Fa l s e,因而当测试串的等价性时,要像前例中的那样,必须用逻辑运算符!将测试条件取反。

当程序运行并以“hello”和“hello”这两个串作为输入时,其输出为:

hello

hello

lengths:5 5

The strings are equal

hellohello

5.2二维数组

5.2.1二维数组的一般形式

C语言允许使用多维数组,简单的多维数组是二维数组。实际上,二维数组是以一维数组为元素构成的数组,要将d说明成大小为(10,20)的二维整型数组,可以写成:

int d[10][20]

请留心上面的说明语句, C不像其它大多数计算机语言那样使用逗号区分下标,而是用方括号将各维下标括起,并且,数组的二维下标均从0计算。

与此相似,要存取数组d中下标为( 3,5)的元素可以写成:

d[ 3 ][ 5 ]

在例5- 3中,整数1到12被装入一个二维数组。

[例5- 3 ]

main()

{

int t,i,num[3][4]

for(t=0; t<3;++t)

for(i=0;i<4;++i)

num[t][i]=(t* 4)+ i+ 1;

}

在此例中, num[0][0]的值为1,num[0][2]的值为3,......,num[2][3]的值为1 2。可以将该数组想象为如下表格:

0 1 2 3

0 1 2 3 4

1 5 6 7 8

2 9 10 11 12

二维数组以行—列矩阵的形式存储。第一个下标代表行,第二个下标代表列,这意味着按照在内存中的实际存储顺序访问数组元素时,右边的下标比左边的下标的变化快一些。图5- 2是一个二维数组在内存中的情形,实际上,第一下标可以认为是行的指针。

记住,一旦数组被证明,所有的数组元素都将分配相应的存储空间。对于二维数组可用下列公式计算所需的内存字节数:

行数×列数×类型字节数=总字节数

因而,假定为双字节整型,大小为( 10,5)的整型数组将需要:10×5×2=100字节,当二维数组用作函数的参数时,实际上传递的是第一个元素(如[ 0 ] [ 0 ])的指针。不过该函数至少得定义第二维的长度,这是因为C编译程序若要使得对数组的检索正确无误,就需要知道每一行的长度。例如,将要接收大小为( 10,10)的二维数组的函数,可以说明如下:

func1(x)

int x[ ][10]

{

.

..

}

第一维的长度也可指明,但没有必要。

C编译程序对函数中的如下语句:

X[2][4]

处理时,需要知道二维的长度。若行长度没定义,那么它就不可能知道第三行从哪儿开[例5-4]用一个二维数组存放某一教师任教的各班学生的分数。假定教师有三个班,每班多有三十名学生。注意各函数存取数组的方法。

#define classes 3

#define grades 30

#include<stdio.h>

main()

{

void enter_grades();

void disp_grades();

int get_grade();

int a[classes] [grades];/*定义二维数组,每行存放一个班学生成绩*/

char ch;

for(;;)

do{/*菜单显示*/

printf("(E)nter grades\n");

printf("(R)eport grades\n");

printf("(Q)uit\n");

ch=toupper(getchar());/*将键盘输入字符转换为大写*/

} while(ch!='E'&& ch!='R'&& ch!='Q');

switch(ch){

case'E':

enter_grades();

break;

case'R':

disp_grades(grade);

break;

case'Q':

exit(0);

}

}

}

void enter_grades(a)

int a[][grades];

{

int t, i;

for(t=0;t<classes;t++)

{

printf("class#%d:\n",t+1);

for(i=0; i<grades; i++)

a[t][i]= get_grade(i);

}

}

int get_grades(num)

int num;

{

char s[80];

printf("enter grade for student#%d:\n",n u m+ 1);

gets(s);/*输入成绩*/

return(atoi(s));

}

void disp_grades(g)/*显示学生成绩*/

int g[ ][grades];

{

int t,i;

for(t=0; t<classes;++t){

printf("class#%d:\n",t+ 1);

for(i= 0; i< grades;++i)

printf("grade for student#%d is%d\n",i+ 1,g[t][i]);

}

}

我们将实际问题简化为共有2个班,每班两个学生,即将程序中的常量定义修改如下:

#define classes 2

#define grades 2

运行程序:

(E)nter grades

(R)eport grades

(Q)uit: e

class#1:

enter grade for student#1: 7 8

enter grade for student#2: 8 9

class#2

enter grade for student#1: 9 8

enter grade for student#2: 9 0

(E)nter grades

(R)eport grades

(Q)uit: r

class#1

grade for student#1 is 78

grade for student#2 is 89

class#2

grade for student#1 is 98

grade for student#2 is 90

(E)nter grades

(R)eport grades

(Q)uit:q

运行程序,我们首先看到一个菜单,选择“ e”输入成绩,选择“ r”显示成绩,选择“q”

退出。atoi()函数用于将实参字符串转换为整型。

5.2.2字符串数组

程序设计中经常要用到字符串数组。例如,数据库的输入处理程序就要将用户输入的命令与存在字符串数组中的有效命令相比较,检验其有效性。可用二维字符数组的形式建立字符串数组,左下标决定字符串的个数,右下标说明串的大长度。例如,下面的语句定义了一个字符串数组,它可存放3 0个字符串,串的大长度为8 0个字符:

char str_array[30][80];

要访问单独的字符串是很容易的,只需标明左下标就可以了。例如,下面的语句以数组str_array中的第三个字符串为参数调用函数gets()。

gets(str_array[2]);

该语句在功能上等价于:

gets(&str_array[2][0]);

但第一种形式在专业程序员编制的C语言程序中更为常见。

为帮助理解字符串数组的用法,研究例5- 5。它以一个字符串数组为基础做简单的文本编辑。

[例5- 5 ]

#include<stdio.h>

#define MAX 100

#define LEN 80

char text [MAX][LEN]

/*一个非常简单的文本编辑器*/

main()

{

register int t,i,j;

for(t=0;t<MAX; t++)/*逐行输入字符串*/

{

printf("%d:",t);

gets(text[t]);

if(! text[t][0])

break;/*空行退出*/

}

for(i= 0; i< t,i++)/*按行,逐个字符输出字符串*/

{

for(j=0; text [i][j];j++)

putchar(text [i][j]);

putchar('\n');

}

}

该程序输入文本行直至遇到一个空行为止,而后每次一个字符地重新显示各行。

5.3多维数组

C语言允许有大于二维的数组,维数的限制(如果有的话)是由具体编译程序决定的。多维数组的一般说明形式为:

Type-specifier name [a][b][c]...[z];

由于大量占有内存的关系,二维或更多维数组较少使用。如前所述,当数组定义之后,所有的数组元素都将分配到地址空间。例如,大小为( 10,6,9,4)的四维字符数组需要10×6×9×4即2160字节。

如果上面的数组是两字节整型的,则需要4320字节,若该数组是双字型的(假定每个双字为8字节)则需要34560字节,存储量随着维数的增加呈指数增长。

关于多维数组,需要注意一点:计算机要花大量时间计算数组下标,这意味着存取多维数组中的元素要比存取一维数组的元素花更多的时间。由于这些和其它原因,大量的多维数组一般采用C语言动态分配函数及指针的方法,每次对数组的一部分动态地分配存储空间。

多维数组传递给函数时,除第一维外,其它各维都必须说明。例如,将数组m定义成:

int m[4][3][6][5];

那么接收m的函数应写成:

func1(d)

int d[][3][6][5];

当然,如果愿意,也可加上第一维的说明。

5.4数组的初始化

5.4.1数组初始化

C语言允许在说明时对全局数组和静态局部数组初始化,但不能对非静态局部数组初始化。

与其它变量相似,数组初始化的一般形式如下:

type-specifier array_name[size1]...[sizen]={value-list};

数值表是一个由逗号分隔的常量表。这些常量的类型与类型说明相容,第一个常量存入数组的第一个单元,第二个常量存入第二个单元,等等,注意在括号“}”后要加上分号。

下列中一个1 0元素整型数组被初始化装入数字1到10:

int i[10]={1,2,3,4,5,6,7,8,9,10};

这意味着i[0]的值为1,而i[9]的值为10。

存放字符串的字符数组的初始化可采用如下简化的形式:

char array_name[size]="string";

例如,以下代码段将str初始化为”hello”。

char str[6]="hello";

上面代码产生和下面代码相同的结果:

char str[6]={'h',' e',' l',' l',' o','\o'};

因为C语言中的字符串都以空( NULL)字符为终结,故要确认定义的数组足够长以存放空字符。这就是为什么h ello只有5个字符,而str要有6个字符长的原因。使用字符串常量时,编译程序自动地在末尾加上空字符。

多维数组初始化的方法与一维数组相同,例如,下式将sqrs初始化为从1到1 0及它们各自的平方数。

int sqrs[10][2]={

1,1,

2,4,

3,9,

4,1 6,

5,2 5,

6,3 6,

7,4 9,

8,6 4,

9,8 1,

1 0,1 0 0,

};

5.4.2变长数组的初始化

设想用数组初始化的方法建立一个如下错误信息表:

char e1[12]="read error\n";

char e2[13]="write error\n";

char e3[18]="cannot open file\n";

可以想象,如果用手工去计算每一条信息的字符数以确定数组的长度是何等的麻烦。利用变长数组初始化的方法可以使C自动地计算数组的长度。变长数组初始化就是使C编译程序自动建立一个不指明长度的足够大的数组以存放初始化数据。使用这种方法,以上信息表变为:

char e1[]="read error\n";

char e2[]="write error\n";

char e3[]="cannot open file\n";

给定上面的初始化,下面的语句printf("%s has length%d\n",e2,sizeof(e2));

将打印出:

write error

has length 13

除了减少麻烦外,应用变长数组初始化使程序员可以修改任何信息,而不必担心随时可能发生的计算错误。

变长数组初始化的方法不仅仅限于一维数组。但在对多维数组初始化时,必须指明除了

第一维以外其它各维的长度,以使编译程序能够正确地检索数组。其方法与数组形式参数的

说明类似。这样就可以建立变长表,而编译程序自动地为它们分配存储空间。例如,下面用

变长数组初始化的方法定义数组sqrs:

int sqrs[ ][2]={

1,1,

2,4,

3,9,

4,1 6,

5,2 5,

6,3 6,

7,4 9,

8,6 4,

9,8 1,

1 0,1 0 0

};

相对定长数组的初始化而言,这种说明的优点在于可以在不改变数组各维长度的情况下,随时增加或缩短表的长度。

5.5应用程序举例

[例5-6]为比赛选手评分。

计算方法:从1 0名评委的评分中扣除一个高分,扣除一个低分,然后统计总分,并除以8,后得到这个选手的后得分(打分采用百分制)。

#include<stdio.h>

main()

{

int score[10];/* 10个评委的成绩*/

float mark;/*后得分*/

int i;

int max=-1;/*高分*/

int min= 101;/*低分*/

int sum= 0;/*10个评委的总和*/

for( i= 0; i< 10; i++)

{

printf("Please Enter the Score of No.%d",i+ 1);

scanf("%d\n",&score[i]);

sum= sum+ score[i];

}

for(i= 0; i< 10; i++)

{

if(score[i]> max)

max= score[i];

}

for(i= 0;i< 10; i++)

{

if(score[i]<min)

min= score[i];

}

mark=( sum- min- max)/ 8.0;

printf("The mark of the player is%.1f\n",mark);

}

[例5-7]数列排序,采用选择法实现对有5个数的数列进行排序。

选择法的算法思想是:(降序)

1.将待排序的n个数放入数组num中,即num[0]、num[1]、... num[n-1]。

2.让num[ 0 ]与后续num[1]... num[ n- 1 ]依次比较,保证大数在前、小数在后。此次比较,num[0]是数组中大。

3.余下n- 1个元素

4. num[1]与num[ 2 ]... num[ n- 1]依次比较,大数在前、小数在后,此次num[ 1 ]是全部元素的大。

num[ n- 2 ]与num[ n- 1 ]比较,num[ n- 2 ]存大数。

num[ n- 1 ]存小数,比较结束,整理有序。

例:待排序5个数为: 44 76 82 63 71

一趟排序: 1次比较:76 44 82 63 71

2次比较:82 44 76 63 71

3次比较:82 44 76 63 71

4次比较:82 44 76 63 71

#include<stdio.h>

main()

{

int num[5];

int i,j;

int temp;

num[0]=94; num[1]=76; num[2]=82; num[3]=63; num[4]=71;

for(i=0; i<4; i++)

for(j=i+1; j<5; j++)

{

if(num[i]>num[j])

{

temp= num[i];

num[i]= num[j];

num[j]= temp;

}

}

for(i=0; i<5; i++)

printf("%4d",num[i]);

printf("ok\n");

}

这是一个非常简单的排序程序,我们只需稍加扩展就可以编制出很多功能强大的管理程序,如学生统计总分、平均排列年级名次等。

[例5-8]简易学生成绩查询系统。

图5- 3为学生成绩登记表,下例程序完成如下功能:

1)根据输入的学生学号,给出各次考试成绩及平均成绩;

2)根据输入考试的次数,打印出该次考试中每个学生的成绩,并给出平均分;

3)根据学号查出学生某次考试成绩;

4)录入考试成绩。

#include<stdio.h>

main()

{

int select;

int i,j;

int score[5][7];

int average=0;

int sum=0;

do{

printf("本程序有4项功能\n");

printf("1、根据学号查询学生成绩\n");

printf("2、根据考试号统计成绩\n");

printf("3、根据考试号和学号查询成绩\n");

printf("4、成绩录入\n");

printf("0、退出\n");

printf("请输入选择(0- 4):");

scanf("%d\n",&select);

switch(select)

{

case 0:

printf("OK\n");

exit(0)

break;

case 1:

printf("输入学号:");

scanf("%d\n",&i);

for(j=1; j<7; j++)

{

printf("第%d科成绩是%d\n",j,score[i][j]);

sum+= score[i][j];

}

average= sum/6;

printf("学生的平均成绩是%d\n",average);

break;

case 2:

printf("输入考试号:");

scanf("%d\n",&j);

for(i=1; i<5; i++)

{

printf("第%d号学生本科成绩是%d\n",i,score[i][j]);

sum+= score[i][j];

}

average= sum/4;

printf("本科平均成绩是%d\n",average);

break;

case 3:

printf("输入学号和考试号:");

scanf("%d%d\n",&,i,&j);

printf("第%d号学生的第%d科考试成绩是%d\n",i, j,score[i][j]);

break;

case 4:

printf("请输入成绩\n");

for(i=1; i<5; i++)

for(j=1; j<7; j++)

scanf("%d\n",&score[i][j]);

break;

default:

break;

}while(1);

}

二、c语言中二维数组按行还是按列存储啊

在c语言里二维数组元素在内存中是按行存放的。

二维数组A[m][n],这是一个m行,n列的二维数组。设a[p][q]为A的第一个元素,即二维数组的行下标从p到m+p,列下标从q到n+q,按“行优先顺序”存储时则元素a[i][j]的地址计算为:

LOC(a[i][j])= LOC(a[p][q])+((i− p)* n+(j− q))* t;

按“列优先顺序”存储时,地址计算为:

LOC(a[i][j])= LOC(a[p][q])+((j− q)* m+(i− p))* t;

存放该数组至少需要的单元数为(m-p+1)*(n-q+1)* t个字节。

扩展资料

C++动态二维数组:

以整形为例,row为行数,col为列数

int**data;//存储二维数组的指针(指向指针的指针。date=x[0][0]的地址。这样标会更好。因为sizeof(date)结果为4不可能存下二维数组)。

//以下实现如何申请内存

data= new int*[row];

for(int k= 0; k< row; k++)

{

data[k]= new int[col];

}

//赋值跟普通二维数组一样例如

data[0][0]= 5;//将二维数组1行1列(C++中称为0行0列)赋值为5

//删除内存

for(int i= 0; i< row;++i)

{

delete [] data[i];//此处的[]不可省略

}

delete [] data;

三、对于二维数组,有行优先顺序和什么两种不同的存储方式

1、行优先和列优先两种。具体情况如下:数组的顺序存储方式由于计算机内存是一维的,多维数组的元素应排成线性序列后存人存储器。数组一般不做插入和删除*作,即结构中元素个数和元素间关系不变化。一般采用顺序存储方法表示数组。

2、二维数组是按行优先存储的即在内存中存一个二维数组时先把数组中第一行的数组元素存完再接着存下一行的直到存完。

3、二维数组在c++中存储,一般是按行存储的,就是将一行当作一维数组进行存储。

4、一是在源码中就给的数值,如a(1,1)=1a(1,2)=0a(2,1)=0a(2,2)=1另外一种是通过外部文件读取其中数据赋值给数组。

5、在C语言中,二维数组a在内存中的存储方式是按行优先(row-major)的方式存储的,也就是说a[0]存放在内存的第一块地址上,紧接着a[1]、a[2]……以此类推。

6、行优先和列优先有三种循环方式:FOR循环、DO-WHILE循环、WHILE循环,字符串之间的比较,它有专门的字符串比较函数:strcmp函数。

四、二维数组在内存中的存放顺序

对于二维数组,有行优先顺序和什么两种不同的存储方式

1、行优先和列优先两种。具体情况如下:数组的顺序存储方式由于计算机内存是一维的,多维数组的元素应排成线性序列后存人存储器。数组一般不做插入和删除*作,即结构中元素个数和元素间关系不变化。一般采用顺序存储方法表示数组。

2、二维数组是按行优先存储的即在内存中存一个二维数组时先把数组中第一行的数组元素存完再接着存下一行的直到存完。

3、二维数组在c++中存储,一般是按行存储的,就是将一行当作一维数组进行存储。

4、一是在源码中就给的数值,如 a(1,1)= 1 a(1,2)= 0 a(2,1)= 0 a(2,2)= 1另外一种是通过外部文件读取其中数据赋值给数组。

5、在C语言中,二维数组a在内存中的存储方式是按行优先(row-major)的方式存储的,也就是说a[0]存放在内存的第一块地址上,紧接着a[1]、a[2]……以此类推。

6、行优先和列优先有三种循环方式:FOR循环、DO-WHILE循环、WHILE循环,字符串之间的比较,它有专门的字符串比较函数:strcmp函数。

在C语言中,写出二维数组元素a[2][3]在内存中的存放顺序

1、二维数组在内存中按行存放。二维数组在c语言中的定义为:int a[x][y]。具体理解为二维数组a,有x行数据,每行数据有y个。解释:当我们在进行数据的存取时,在无x的条件下不可能取出值。

2、二维数组在c++中存储,一般是按行存储的,就是将一行当作一维数组进行存储。例如:a[2][2]这个二维数组,其在内存中存储顺序为:a[0][0]a[0][1]//先存储第一行a[1][0]a[1][1]//再存储第二行。

3、C语言中二维数组是按行优先存储的即在内存中存一个二维数组时先把数组中第一行的数组元素存完再接着存下一行的直到存完。

4、在c语言里二维数组元素在内存中是按行存放的。二维数组A[m][n],这是一个m行,n列的二维数组。

5、在C语言中,二维数组元素在内存中的存放顺序是(按行存放)即在内存中线顺序存放第一行的元素,再存放第二行的元素。

6、二维数组元素在内存中的存放顺序是按行存放。当进行数据的存取时,在无x的条件下不可能取出值。但是在没有y的条件下,可以通过地址取出x行的某个值。

二维数组元素在内存中的存放顺序是

二维数组元素在内存中的存放顺序是按行存放。当进行数据的存取时,在无x的条件下不可能取出值。但是在没有y的条件下,可以通过地址取出x行的某个值。

在c语言里二维数组元素在内存中是按行存放的。二维数组A[m][n],这是一个m行,n列的二维数组。

如何在一维存储器中存放二维数组,可有两种方式:一种是按行排列,即放完一行之后顺次放入第二行。另一种是按列排列,即放完一列之后再顺次放入第二列。在C语言中,二维数组是按行排列的。

相关文章

TCL电视43V6E图文测评

TCL电视43V6E图文测评

很多小伙伴在关注TCL电视43V6E怎么样?质量好不好?使用测评如何?本文综合已购用户的客观使用分享和相应的优惠信息,为大家推荐一款高性价比的产品,一起来看看吧。...

小米(MI)电视RedmiX65T质量怎么样

小米(MI)电视RedmiX65T质量怎么样

很多小伙伴在关注小米(MI)电视RedmiX65T怎么样?质量好不好?使用测评如何?本文综合已购用户的客观使用分享和相应的优惠信息,为大家推荐一款高性价比的产品,一起来看看...

海信电视65E3G-PRO使用心得反馈

海信电视65E3G-PRO使用心得反馈

很多小伙伴在关注海信电视65E3G-PRO怎么样?质量好不好?使用测评如何?本文综合已购用户的客观使用分享和相应的优惠信息,为大家推荐一款高性价比的产品,一起来看看吧。...

海信/Hisense55E3H口碑怎么样

海信/Hisense55E3H口碑怎么样

很多小伙伴在关注海信/Hisense55E3H怎么样?质量好不好?使用测评如何?本文综合已购用户的客观使用分享和相应的优惠信息,为大家推荐一款高性价比的产品,一起来看看吧。...

小米(MI)电视55英寸全面屏Pro使用感受如何

小米(MI)电视55英寸全面屏Pro使用感受如何

很多小伙伴在关注小米(MI)电视55英寸全面屏Pro怎么样?质量好不好?使用测评如何?本文综合已购用户的客观使用分享和相应的优惠信息,为大家推荐一款高性价比的产品,一起来看...

Camorama凯眸4K全景运动摄像机车载支架测评怎么样

Camorama凯眸4K全景运动摄像机车载支架测评怎么样

很多小伙伴在关注Camorama凯眸4K全景运动摄像机车载支架怎么样?质量好不好?使用测评如何?本文综合已购用户的客观使用分享和相应的优惠信息,为大家推荐一款高性价比的产品...