C语言switch和数组的意义

C语言中的switch语句和数组的意义是什么,怎么理解它们?
这些我一点都不懂,简单讲解下
谭浩强的C程序设计好理解吗?
C程序设计 C++程序设计 哪本好点
case 1 case 2 default这些语句是什么意思?作用是什么?

先说一下switch()的用法
相信你看完就能看明白这道题了。
1.switch()是多分支选择语句
2.switch()括号里的表达式可以为任何类型,此题就是看其余数的值与下面 的 哪条case语句对应。
3.与哪条case语句对应上,就执行那条语句,直到遇到break语句退出本条 switch()语句结构,否则接着执行下面的case语句,直到遇到break或者执行完最后一条case语句结束。
4.这里的default与case语句一样,你可以把它看成是case其他,所以可以放到任何其他的case位置。
5.当然最后一条语句可以不用break,因为已经执行到最后一条,自动就退出switch().

至于m++;你可以这样理解,m在前,先用m的值完成本条语句,++在后,那么就完成上条语句后再自加1,然后开始下条语句的执行。

对数组类型的说明应注意:
1)数组的类型实际上是数组元素的取值类型。
2)数组名的书写应符合标识符的书写规范。
3)数组名不能与其他变量名相同。
4)常量表达式表示数组元素的个数,但是其下标从0开始计算
5)不能在方括号中用变量来表示元素的个数,但是可以用符号
常数或常量表达式。
6)允许在同一个类型说明中,说明多个数组和多个变量。
数组元素的表示方法
一般比较简单就是数组名[下标]来引用,先定义后用,如果
是小数的话,直接自动取整。
数组赋值分为:初始化赋值和动态赋值
初始化赋值一般形式为:
static 类型说明符 数组名[常量表达式]={值,值......};
static表示静态存储类型,c语言规定只有静态存储数组和外部数组
才可做初始化赋值。
c语言对数组的初始化赋值还有几个规定:
1)可以只给部分元素赋值。
2)只能给元素逐个赋值,不能给数组整体赋值。
3)如不给可初始化的数组赋初值,在在数组说明中,可以不给出数组
元素的个数。
下面看一下多维数组
主要看一下二维数组,其他的就可以用二维数组类推得到
二维数组的类型说明的一般形式是:
类型说明符 数组名[常量表达式1][常量表达式2]...;
在c语言中二维数组是按行排列的
二维数组的表示方法:
数组名[下标][下标]
二维数组的初始化
二维数组初始化也是在类型说明时给各下标变量赋以初值。 二维数组可
按行分段赋值,也可按行连续赋值。
二维数组的初始化还应该注意:
1)可以只对部分元素赋初值,未赋初值的元素自动取为0。
2)如对全部元素赋初值,则第一维的长度可以不给出。
字符数组:
用来存放字符变量的数组称为字符数组。
C语言允许用字符串的方式对数组作初始化赋值。例如:
static char c[]={'c', ' ','p','r','o','g','r','a','m'}; 可写为:
static char c[]={"C program"}; 或去掉{}写为:
sratic char c[]="C program";
用字符串方式赋值比用字符逐个赋值要多占一个字节, 用于存放字符串结
束标志'\0'。上面的数组c在内存中的实际存放情况为: C program\0`\0'是
由C编译系统自动加上的。由于采用了`\0'标志,所以在用字符串赋初值时一
般无须指定数组的长度, 而由系统自行处理。在采用字符串方式后,字符数
组的输入输出将变得简单方便。 除了上述用字符串赋初值的办法外,还可用
printf函数和scanf函数一次性输出输入一个字符数组中的字符串, 而不必
使用循环语句逐个地输入输出每个字符。
void main()
{
static char c[]="BASIC\ndBASE";
printf("%s\n",c);
} printf("%s\n",c);
注意在本例的printf函数中,使用的格式字符串为"%s", 表示输出的是一
个字符串。而在输出表列中给出数组名则可。 不能写为: printf("%s",c[]);
void main()
{
char st[15];
printf("input string:\n");
scanf("%s",st);
printf("%s\n",st);
} char st[15];
本例中由于定义数组长度为15, 因此输入的字符串长度必须小于15,
以留出一个字节用于存放字符串结束标志`\0`。 应该说明的是,对一个字
符数组,如果不作初始化赋值,则必须说明数组长度。还应该特别注意的是,
当用scanf函数输入字符串时,字符串中不能含有空格,否则将以空格作为串
的结束符。例如运行例4.8,当输入的字符串中含有空格时,运行情况为:
input string:this is a book this 从输出结果可以看出空格以后的字符
都未能输出。 为了避免这种情况, 可多设几个字符数组分段存放含空格的
串。程序可改写如下:
Lesson
void main()
{
char st1[6],st2[6],st3[6],st4[6];
printf("input string:\n");
scanf("%s%s%s%s",st1,st2,st3,st4);
printf("%s %s %s %s\n",st1,st2,st3,st4);
}
本程序分别设了四个数组, 输入的一行字符的空格分段分别装入四个数组。
然后分别输出这四个数组中的字符串。在前面介绍过,scanf的各输入项必须以
地址方式出现,如 &a,&b等。但在例4.8中却是以数组名方式出现的,这是为
什么呢?这是由于在C语言中规定,数组名就代表了该数组的首地址。 整个
数组是以首地址开头的一块连续的内存单元。如有字符数组char c[10],在
内存可表示如图4.2。设数组c的首地址为2000,也就是说c[0]单元地址为2000。
则数组名c就代表这个首地址。因此在c前面不能再加地址运算符&。如写作
scanf("%s",&c);则是错误的。 在执行函数printf("%s",c) 时,按数组名c
找到首地址,然后逐个输出数组中各个字符直到遇到字符串终止标志'\0'为止。
字符串常用函数:
用于输入输出的字符串函数在使用前应包含头文件"stdio.h",使用其他字符串
函数则应包含头文件"string.h".下面介绍几个常用的字符串函数:
1)字符串输出函数 puts 格式:puts(字符数组名) 功能:把字符数组中的字符
串输出到显示器。
#include"stdio.h"
main()
{
static char c[]="BASIC\ndBASE";
puts(c);
}
2)字符串输入函数gets 格式:gets(字符数组名) 功能:从标准输入设备上
输入一个字符串。
#include"stdio.h"
main()
{
char st[15];
printf("input string:\n");
gets;
puts;
}
tips:gets函数并不以空格作为字符串输入结束的标志,而只是以回车作为输入
结束,这是与scanf不同的部分
3)字符串连接函数strcat 格式:strcat(字符数组名1,字符数组名2)
功能:把字符数组2中的字符串连接到字符数组1中字符串后面,并删去字符串
1后的串标志"\0",本函数返回字符数组1的首地址。
#include"string.h"
main()
{
static char st1[30]="My name is ";
int st2[10];
printf("input your name:\n");
gets(st2);
strcat(st1,st2);
puts(st1);
}
4)字符串拷贝函数strcpy 格式:strcpy(字符数组名1,字符数组名2)
功能:把字符数组2中的字符串拷贝到字符数组1中,串结束标志 "\0"也一同
拷贝,字符数组2也可以是一个字符常量,就相当于把一个字符串赋予一个字符数组
#include"string.h"
main()
{
static char st1[15],st2[]="C Language";
strcpy(st1,st2);
puts(st1);
printf("\n");
}
5)字符串比较函数strcmp格式:strcmp(字符数组1,字符数组2) 功能:
按照ASCII码顺序比较两个数组中的字符串,并有函数返回值返回比较结果
#include"string.h"
main()
{
int k;
static char st1[15],st2[]="C Language";
printf("input a string:\n");
gets(st1);
k=strcmp(st1,st2);
if(k==0) printf("st1=st2\n");
if(k>0) printf("st1>st2\n");
if(k<0) printf("st1<st2\n");
}
6)测字符串长度的函数strlen 格式:strlen(字符数组名) 功能:
测字符串的实际长度(不含字符串结束标志"\0")并作为函数返回值
#include"string.h"
main()
{
int k;
static char st[]="C Language";
k=strlen;
printf("The lenth of the string is %d\n",k);
}
程序举例:
例一:
main()
{
int i,j,p,q,s,n,a[11]={127,3,6,28,54,68,87,105,162,18};
for(i=0;i<10;i++)
{
p=i;q=a[i];
for(j=i+1;j<10;j++)
if(q<a[j]) {p=j;q=a[j];}
if(p!=i)
{
s=a[i];
a[i]=a[p];
a[p]=s;
}
printf("%d",a[i]);
}
printf("\ninput number:\n");
scanf("%d",&n);
for(i=0;i<10;i++)
if(n>a[i])
{for(s=9;s<=i;s--) a[s+1]=a[s];
break;}
a[i]=n;
for(i=0;i<10;i++)
printf("%d",a[i]);
printf("\n");
}
例二:
main()
{
static int a[][4]={3,16,87,65,4,32,11,108,10,25,12,27};
int b[3],i,j,l;
for(i=0;i<=2;i++)
{
l=a[i][0];
for(j=1;j<=3;j++)
if(a[i][j]>l) l=a[i][j];
b[i]=l;
}
printf("\narray a:\n");
for(i=0;i<=2;i++)
{
for(j=0;j<=3;j++)
printf("%5d",a[i][j]);
printf("\n");
}
printf("\narray b:\n");
for(i=0;i<3;i++)
printf("%5d",b[i]);
printf("\n");
}
例三:
void main()
{
char st[20],cs[5][20];
int i,j,p;
printf("input country's name:\n");
for(i=0;i<5;i++)
gets(cs[i]);
printf("\n");
for(i=0;i<5;i++)
{
p=i;strcpy(st,cs[i]);
for(j=i+1;j<5;j++)
if(strcmp(cs[j],st)<0) {p=j;strcpy(st,cs[j]);}
if(p!=i)
{strcpy(st,cs[i]);
strcpy(cs[i],cs[p]);
strcpy(cs[p],st);
}
puts(cs[i]);
printf("\n");
温馨提示:答案为网友推荐,仅供参考
第1个回答  2009-08-17
通俗的讲,switch语句是一个分支语句,case的选项表示每种可能。比如,现在我们做个逻辑
switch(m)
{
case'1' : fn1();break;
case'2' : fn2();break;
default : fn3();
}
这个选择分支语句的意思就相当明显,对变量m的值进行判断,若为1,执行函数fn1(),然后跳出switch语句;若为2,执行fn2(),然后跳出switch语句;如不为考虑的结果,则执行default语句。
其中,default语句建议写着,不要怕麻烦。这使得这个判断更为严谨。此外,switch语句可以转换成if...else..语句。
数组,定义为 数据类型 数组名[数组长度],例如 unsigned char Array[20]
表示定义一个长度为20的无符号char型数组。可以这样理解一个数组,数据类型表示数组每个单元的里数值的“范围”。数组名为这个数组单元的起始地址。长度为20,简单的说可以存放20个数据,最多!
谭浩强的书,我个人觉得不错,比较全面,建议多多理解基础,如数据类型,数值转换,溢出,这些概念。语法相对比较简单。主要体会程序设计的一种思维方式,以及书写方式,还有程序的模块化(精髓)。
c与c++,我建议先学c,c是基础,要多加练习,多阅读程序。c++是c的一个扩展。后期有基础学是很快的。
好了,就说这么多,有什么不懂得地方可以给我发邮件[email protected]
第2个回答  推荐于2016-11-30
C和C++事两门不同的语言,各有千秋,不能定性的衡量谁好谁坏,
switch语句简单来说就是一个常量比较,switch() 括号中的是一个常量,用这个常量和switch(){} 大括号中的每一个case后面的常量比较,如果有匹配的就执行对应case中的语句,如果没有,默认有个default的,数组,拿一维数组做例子,格式是例如:int a[10];a是我们起的数组名字,10是数组的大小,int表示数组中每一个元素的类型,这个数组的含义就是定义一个可以存储10个int类型数据的空间...本回答被提问者采纳
第3个回答  推荐于2018-05-04

1、C语言中switch语句是多分支选择性语句,switch语句的作用是根据不同的条件判断执行不同的语句。

例子:

switch(表达式){
case 1   //执行语句体 1
  break;
case 2   //执行语句体 2
  break;
default; //执行语句体 n
  break;
}

switch后面内的表达式,可以是整形表达式或者是字符型表达式,也可以是枚举型数据。表达式的值与case语句后面的植逐个进行匹配,如果匹配得上,就执行该case语句后面的执行与具体,然后通过break语句跳出该循环。如果最终没有case语句能与表达式的值相匹配,则执行default后面的执行语句体。


2、数组,顾名思义,是相同类型的数组成的一个组,也就是说是把相同类型的一系列数据统一编制到某一个组别中。这样就可以通过数组名+索引号简单快捷的操作大量数据。这就和全校学生一样,把学生分成多个班级,每个学生都是班级中的一员,如果要找张三,如果没有班级的话,就要在全校学生中一个一个寻找,一直到找到为止;但是如果引入了班级,就可以在某某班级中寻找张三,这样就更加方便快速了。

本回答被网友采纳
第4个回答  2009-08-17
switch就是条件分支语句,比如
switch(a)
{
case 1:...,break;
case 2:...,break;
default:...
}
就相当于
if(a==1)...
else if(a==2)...
...
else ....

数组是高级编程语言提供的用以访问大量数据的便捷方法.我们知道,变量实际上就是数据在内存中的地址,那么如果没有数组的话,我们要访问一百万个整型数据的话,就需要有一百万个变量,这是非常恐怖的事情.但如果有了数组的话,我们就可以只用两个变量(数组首地址,数组下标)加上一个循环来访问这一百万个变量了.