在c语言计算器 如何同时计算两个for循环,前一个循环i--,一个...

C语言支持一维数组和多维数组。如果一个数组的所有元素都不是数组,那么该数组称为一维数组。
一维数组的定义方式
在C语言中使用数组必须先进行定义。一维数组的定义方式为:
& & 类型说明符 数组名 [常量表达式];
其中,类型说明符是任一种基本数据类型或构造数据类型。数组名是用户定义的数组标识符。方括号中的常量表达式表示数据元素的个数,也称为数组的长度。例如:
int a[10];
/* 说明整型数组a,有10个元素 */
float b[10], c[20];
/* 说明实型数组b,有10个元素,实型数组c,有20个元素 */
char ch[20];
/* 说明字符数组ch,有20个元素 */
对于数组类型说明应注意以下几点:
1) 数组的类型实际上是指数组元素的取值类型。对于同一个数组,其所有元素的数据类型都是相同的。
2) 数组名的书写规则应符合标识符的书写规定。
3) 数组名不能与其它变量名相同。例如:
float a[10];
是错误的。
4) 方括号中常量表达式表示数组元素的个数,如a[5]表示数组a有5个元素。但是其下标从0开始计算。因此5个元素分别为a[0], a[1], a[2], a[3], a[4]。
5) 不能在方括号中用变量来表示元素的个数,但是可以是符号常数或常量表达式。例如:
#define FD 5
int a[3+2],b[7+FD];
是合法的。但是下述说明方式是错误的。
6) 允许在同一个类型说明中,说明多个数组和多个变量。例如:
int a,b,c,d,k1[10],k2[20];
一维数组元素的引用
数组元素是组成数组的基本单元。数组元素也是一种变量, 其标识方法为数组名后跟一个下标。下标表示了元素在数组中的顺序号。数组元素的一般形式为:
& & 数组名[下标]
其中下标只能为整型常量或整型表达式。如为小数时,C编译将自动取整。例如:
& & a[i+j]
& & a[i++]
都是合法的数组元素。
数组元素通常也称为下标变量。必须先定义数组,才能使用下标变量。在C语言中只能逐个地使用下标变量,而不能一次引用整个数组。例如,输出有10个元素的数组必须使用循环语句逐个输出各下标变量:
for(i=0; i&10; i++)
printf(&%d&,a[i]);
而不能用一个语句输出整个数组。因此,下面的写法是错误的:
printf(&%d&,a);
【例7-1】使用for循环为一个数组赋值,并将数组倒叙输出。
#include &stdio.h&
int main(void){
int i,a[10];
for(i=0;i&=9;i++)
for(i=9;i&=0;i--)
printf(&%d &,a[i]);
【例7-2】将上面的例子稍微改变一下。
#include &stdio.h&
int main(void){
int i,a[10];
for(i=0;i&10;)
for(i=9;i&=0;i--)
printf(&%d&,a[i]);
一维数组的初始化
给数组赋值的方法除了用赋值语句对数组元素逐个赋值外, 还可采用初始化赋值和动态赋值的方法。
数组初始化赋值是指在数组定义时给数组元素赋予初值。数组初始化是在编译阶段进行的。这样将减少运行时间,提高效率。初始化赋值的一般形式为:
& & 类型说明符 数组名[常量表达式] = { 值, 值&&值 };
其中在{ }中的各数据值即为各元素的初值,各值之间用逗号间隔。例如:
int a[10]={ 0,1,2,3,4,5,6,7,8,9 };
a[0]=0; a[1]=1 ... a[9]=9;
C语言对数组的初始化赋值还有以下几点规定:
1) 可以只给部分元素赋初值。当{ }中值的个数少于元素个数时,只 给前面部分元素赋值。例如:
int a[10]={0,1,2,3,4};
表示只给a[0]~a[4]5个元素赋值,而后5个元素自动赋0值。
2) 只能给元素逐个赋值,不能给数组整体赋值。例如给十个元素全部赋1值,只能写为:
int a[10]={1,1,1,1,1,1,1,1,1,1};
而不能写为:
int a[10]=1;
3) 如给全部元素赋值,则在数组说明中,可以不给出数组元素的个数。例如:
int a[5]={1,2,3,4,5};
int a[]={1,2,3,4,5};
一维数组程序举例
可以在程序执行过程中,对数组作动态赋值。这时可用循环语句配合scanf函数逐个对数组元素赋值。
【例7-4】输入10个数字并输出最大值。
#include &stdio.h&
int main(void){
int i,max,a[10];
printf(&input 10 numbers:\n&);
for(i=0;i&10;i++)
scanf(&%d&,&a[i]);
for(i=1;i&10;i++)
if(a[i]&max) max=a[i];
printf(&maxmum=%d\n&,max);
本例程序中第一个for语句逐个输入10个数到数组a中。 然后把a[0]送入max中。在第二个for语句中,从a[1]到a[9]逐个与max中的内容比较,若比max的值大,则把该下标变量送入max中,因此max总是在已比较过的下标变量中为最大者。比较结束,输出max的值。
【例7-5】输入10个数字并按从大到小的顺序排列。
#include &stdio.h&
int main(void){
int i,j,p,q,s,a[10];
printf(&\n input 10 numbers:\n&);
for(i=0;i&10;i++)
scanf(&%d&,&a[i]);
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];
a[i]=a[p];
printf(&%d&,a[i]);
本例程序中用了两个并列的for循环语句,在第二个for 语句中又嵌套了一个循环语句。第一个for语句用于输入10个元素的初值。第二个for语句用于排序。本程序的排序采用逐个比较的方法进行。在i次循环时,把第一个元素的下标i赋于p,而把该下标变量值a[i]赋于q。然后进入小循环,从a[i+1]起到最后一个元素止逐个与a[i]作比较,有比a[i]大者则将其下标送p,元素值送q。一次循环结束后,p即为最大元素的下标,q则为该元素值。若此时i&p,说明p,q值均已不是进入小循环之前所赋之值,则交换a[i]和a[p]之值。 此时a[i]为已排序完毕的元素。输出该值之后转入下一次循环。对i+1以后各个元素排序。
更多关于排序的内容请查看:C语言流水灯循环右移动,我想问下,为什么上面第一个FOR语句的后面是左移,下面的FOR语句就是右移了啊?_百度知道
C语言流水灯循环右移动,我想问下,为什么上面第一个FOR语句的后面是左移,下面的FOR语句就是右移了啊?
#include&reg52.h&
//52单片机头文件#include &intrins.h& //包含有左右循环移位子函数的库#define uint unsigned int
//宏定义#define uchar unsigned char
//宏定义sbit beep=P2^3;void delay(uint z)
//延时函数,z的取值为这个函数的延时ms数,如delay(200);大约延时200ms.{
//delay(500);大约延时500ms. uint x,y; for(x=z;x&0;x--)
for(y=110;y&0;y--); }void main()
//主函数{ uchar a,i; while(1)
//大循环 {
//赋初值
for(i=0;i&8;i++)
//左移
//点亮小灯
//开启蜂鸣器
delay(50); //延时50毫秒
//关闭蜂鸣器
delay(50);
//再延时50毫秒
a=_crol_(a,1); //将a变量循环左移一位
for(i=0;i&8;i++)
//右移
//点亮小灯
//开启蜂鸣器
delay(50); //延时50毫秒
//关闭蜂鸣器
delay(50);
//再延时50毫秒
a=_cror_(a,1); //将a变量循环右移一位
提问者采纳
关键语句在于两个for中的“a=_crol_(a,1);”和“a=_cror_(a,1);”,可以发现用的是两个不同的函数_crol_()和_cror_(),一个左移,一个右移
提问者评价
这样啊,一直没看到,晕,害我研究了半天,谢了啊
其他类似问题
按默认排序
其他1条回答
每次左移一位,显示8次,a=0x7f;
0x 每次右移一位 ,显示 8次
我吧其中一段单独测试的时候,2个初值我都改过,但是结果都一样都是向左移动
流水灯的相关知识
等待您来回答
您可能关注的推广回答者:
下载知道APP
随时随地咨询
出门在外也不愁C语言 一个循环输出两个数组疑惑
C语言 一个循环输出两个数组疑惑 100
现有两个具有8个元素的double数组,数组内容自己定义。现在要使用一个循环来显示两个数组中的内容,第一个数组在一行中显示,而第二个数组中的每个元素在第一个数组的对应元素之下进行显示,注意,只能用一个循环。我不明白一个循环如何做到输出两行数组,且数组元素分别一一对应。希望大家提示一下,怎样做到这一操作,谢谢。
#include "stdio.h"void main(){&double a[8]={0,1,2,3,4,5,6,7};&double b[8]={0,1,2,3,4,5,6,7};&for (int i=0;i&16;i++)&{&& &if(i&8)&&printf(" %.1f ",a[i]);&& &if(8==i)&& & printf("\n");&& &if(i&=8)&& & & &printf(" %.1f ",b[i-8]);&}}
下面是个例子& 不知道是否可行
#include &iostream&void main(){&double a[8]={0,1,2,3,4,5,6,7};&double b[8]={0,1,2,3,4,5,6,7};&for (int i=0;i&16;++i)&{&&& if(i&8)&&cout&&a[i]&&" ";&&& if(8==i)&&&& cout&&&&& if(i&=8)&&&&&&& cout&&b[i]&&" ";&}}
呃……………你的那一个是C++,我没有学,你能用C语言表达出来吗?或者文字提示一下也可以,不一定要代码。
嗯& 其实大部分也是一样的啊& 主要是 用一个可以循环2个的数字用于控制循环 然后便是用if语句来控制的输出
#include &iostream& //相当与 "stdio.h"void main(){&double a[8]={0,1,2,3,4,5,6,7};&double b[8]={0,1,2,3,4,5,6,7};&for (int i=0;i&16;++i)&{&&& if(i&8)//只输出8个&&cout&&a[i]&&" ";//这里相当于 printf()函数&&& if(8==i)&&&& cout&&&&& if(i&=8)//只输出8个&&&&&&& cout&&b[i-8]&&" "; //这里要注意要减去8&}}
其他回答 (2)
用if控制语句:
#include &stdio.h&
int main(void)
{
int a1[]={1,3,5,7,9,11,13,15};
int a2[]={2,4,6,8,10,12,14,16};
for(i=0;i&16;i++)
printf(&%d&,a1[i]);
printf(&\n&);
printf(&%d&,a2[i-8]);
printf(&\n&);
return 0;
}
相对比较容易想到的有两个办法我手头上没有编译器,就单纯的说给你听吧方法一你可以通过一个循环,每个数组输出一个数据,期间利用gotoxy()来改变输出的位置方法二就像楼上的仁兄,也是一次循环,但是循环16次,期间加入判断,如果是前8次循环,则输出数组一的数据,如果后八次循环,则输出数组二的数据。
等待您来回答
编程领域专家C语言循环for(i=1,j=6;++i!=j--;) s=i+j;将执行几次 标准答案2次求解释_百度知道
C语言循环for(i=1,j=6;++i!=j--;) s=i+j;将执行几次 标准答案2次求解释
提问者采纳
循环条件为 2!=6, ++i 是先计算加1,循环条件为 4!=4,关键是循环条件 ++i!=j--,再计算减1, 执行后
i=2,使用加1后结果,2次循环时, j--是先使用j值, 条件不成立, j=4,循环条件为 3!=5,首次循环时, j=5, 执行后
i=3,3次循环时,退出循环。所以只执行2次。,这是一个运算符执行顺序的问题,
采纳率100%
其他类似问题
其他3条回答
2和6,s=83和5,s=84和4,结束,
第1次: i = 1, j = 6; 判断 ++i是2,j--值为6,不等,执行;i值变为2,j值变为5第2次:判断++i是3,j--值为5,不等,执行;i值变为3,j值变为4第3次:判断++i是4,j--值为4,相等,不执行(i值变为4,j值变为3)
++i&是先i+1再判断条件表达式j--&是先j-1再判断条件表达式再看for循环的流程:因此,上面的表达式可以逐步解释为:一、赋初值&i=1&j=6二、判断条件;++i!=j--,此时i=2&&j=6&条件成立,循环内语句执行一次&s=7(i=2&j=5)三、判断条件;++i!=j--,i=3&j=5&条件成立,循环内语句执行一次&s=7(i=3&j=4)四、判断条件;++i!=j--,i=4&j=4&条件不成了,退出循环。i=4&h=4
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁}

我要回帖

更多关于 c语言计算器 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信