收藏 分销(赏)

编写C程序时应该注意的.doc

上传人:仙人****88 文档编号:8469398 上传时间:2025-02-14 格式:DOC 页数:49 大小:67.95KB 下载积分:10 金币
下载 相关 举报
编写C程序时应该注意的.doc_第1页
第1页 / 共49页
编写C程序时应该注意的.doc_第2页
第2页 / 共49页


点击查看更多>>
资源描述
编写C程序时应该注意的: 编写程序必须: 一。包含并且仅仅包含一个main() 二。程序体应该在 { 和 }之间书写 三。变量必须 "先定义后使用" 如必须有 int i,j; 才能有 i=10;j=j+1; printf("%5d",j); 这样的语句。 不能写成inti,j; int及其他类型关键字和后面的变量之间要有空格。 四。语句结尾必须有; 但函数首部不能加分号; 如void main() ;错误 五。注意关键字的书写准确 如 printf 不要写成 print 六。学会看编译时的错误提示 如 statement missing ; 表示该高亮提示行没有结尾; 变量定义时注意其类型,需要看该变量的应用之处,确定该变量应该是整型、实型或者字符型 如:如果要执行 i=j%k; 这样运算 则i,j,k 都应该是整型。 若要计算原面积 s=pi*r*r; 则 s,pi,r 都应该是实型。 scanf("%f,%d,%c",&i,&j,&k); 描述向计算机输入三个值按顺序分别给变量i,j,k。 其中i,j,k的类型对应分别是 实型,整型,字符型。即该scanf语句之前应该有定义: float i; int j; char k; 运行时在黑屏输入界面下输入: 10.53,88,t 其中: 10.53是实型数据 对应%f的格式控制字符要求,将其赋给输入列表的第一个变量i,(注意变量名是i,但用在scanf中必须写成&i). 88是整型数据 对应%d的格式控制字符要求,将其赋给输入列表的第二个变量j 't'是字符型数据(运行输入时不要带 ' ') 对应%c的格式控制字符要求,将其赋给输入列表的第三个变量k 注意输入时用 “,” 分隔 因为在上面 %f,%d,%c 中间是指定用 ‘,’分隔的。 如果写成scanf("%f:%d:%c",&i,&j,&k); 则运行时输入 10.53:88:t 如果写成scanf("%f%d%c",&i,&j,&k); 则运行时输入 10.53 88 t 中间用空格分隔。 printf("%7.3f",k);的含义是 : 输出实型变量k的值,并且k的值实际占用7个字符位置,小数位数为三位。 如果k的实际值占不满7个字符宽,则输出时数据前面(左边)系统自动补上相应空格,使其占够7位 如果k的实际值多于7个字符宽,则系统自动扩展宽度,显示全部真实值。 若改为 %-7.3f含义是: 如果k的实际值占不满7个字符宽,则输出时数据后面(右边)系统自动补上相应空格,使其占够7位 如printf("%7.3f,%-7.2f;;;%12.3f,%-12.2f",122.8899,122.8899,122.8899,122.8899); 则输出为: 122.890,122.89_;;;_____122.890,122.89______ _表示空格 _____5个空格 ______6个空格 变量定义时应该注意, <1>.turbo c中定义语句应该放到程序开始的地方,在所有执行语句之前如 int a=0,b=1,c=3; float k; k=a+b-c; 是正确的,而 int a=0,b=1,c=3; a=b-c; float k; k=1; 则是不正确的。 *** 但在vc中两者都是正确的 <2>.定义变量时候注意类型声明的关键字必须和变量之间存在空格。 int k,l,j;是正确的,而 intk,l,j;是错误的。 <3>.变量定义时,还要注意变量的范围。如果想把10!赋值给变量s,不能把s定义为int, 因为10!的结果超过了int的最大值32767。(c++下int范围已经增大为4字节了) 特殊地方 (1)。c语言中乘法运算符*不能省略,即 5/9(f-32)应当写成: 5/9*(f-32) (2)。注意5/9的结果是0而不是0.555556应该写成 5.0/9 5/9.0 5.0/9.0都对;同种数据类型数据之间运算结果仍为该类型,保持不变。 (3)。混合运算时,必须先考虑运算符之间的优先级,优先级高的先运行; 如果优先级一样的情况下,按各运算符的结合性进行。 (4)。i++,i的值先拿出来用,然后再自增。 i=1; j=i++; ------j的值为1; ++i,i的值先自增然后再拿出来用。 i=1; j=++i; ------j的值为2; 有关文件的问题: (1)。c语言的源文件名应该是不多于8个字符组成,并注意以.c(vc中为.cpp)结尾。 (2)。文件名中应该只有一个"."不能有 12.3.c 这样的名字。 (3)。文件名中不应出现汉字字符以及其他特殊字符,如rrr(1).c就会引起问题。 (4)。定义一个文件比如第一章第三题可以采用类似如下的命名方式:1-3.c。 (5)。程序运行时,出现黑屏,可能是在等待用户输入,因为使用了scanf语句。 也可能是死循环,此时同时按下ctrl和break键,强行中断。 (6)。编辑好文件后先保存再调试运行! (7)。每次编好的程序都应该给一个新的文件名,而不能仅仅沿用以前的名字,否则将会把以前编写好的文件覆盖掉。 printf("格式控制" ,输出表列); printf("%d,%8.4f \n %-10.2s--\t--r=%6d", 10 , 888.888 , "suabngu" , k ); (k是整型变量并且前面已经赋值)。 <1>"格式控制"中普通字符 原样照印,如前面的 , 空格 - r= 。 <2>"格式控制"中转义字符按照表示含义输出,如前面的 \n \t 。 <3>"格式控制"中控制字符和后面 输出表列 中数据对象一一对应即从个数、类型、顺序上一致。 如上面 %d 对应 10 %8.4f 对应 888.888 %-10.2s 对应 "suabngu" 表示输出该字符串到屏幕,但仅输出该字 符串的前两个字符即su,并且其右补8个空格。 %6d 对应 k scanf("格式控制",地址表列); scanf("a=%d, f=%10f, k=%c : " ,&i,&j,&k); i,j,k分别是整型,实型,字符型变量 注意变量前面的& <1>"格式控制"中普通字符 程序运行黑屏时原样照输 如前面的语句运行时,黑屏状态下应该输入 a=10, f= (此处可以有0个或者多个空格)90.89, k=$ : 回车符 。 <2>"格式控制"中转义字符按照表示含义输入 。 <3>"格式控制"中控制字符和后面 地址表列 中地址对象一一对应即从个数、类型、顺序上一致。 %d对应 &i %10f对应 &j %c对应 &k 注意都是给变量赋值,即相应屏幕输入值给了变量i,j,k。但形式上必须要前加&,原因以后再说。 <4>地址表列中不能出现常量,比如123,'*',12.333都是不对的。 16,关于赋值语句的说明: <1>.赋值语句形式为 变量名=表达式 ; 注意:赋值号(=)左边只能为 变量名,-----常量、表达式不允许出现在赋值号左边。 赋值号(=)右边的表达式可以是常量、变量、表达式的形式。 <2>复合的赋值语句 编写C程序时应该注意的问题(选择、循环、数组部分): 1. 选择结构中if和else均只能“管辖”其下的一条语句,当功能实现需要多条语句时必须将这多条语句用 { }括起来,构成复合语句。如: if ( x>y ) x=1; -----当只有一条语句时{ } 可以省略 else x=y+1; -----当只有一条语句时{ } 可以省略 if ( x>y ) { x=1; y++; } -----当有多条语句时,用{ }括起来 else { x=y+1; --y; } -----当有多条语句时,用{ }括起来 2. 选择结构if (条件) 后面不能加 ; 否则计算机认为其后跟了一条空语句,不能正确表示功能含义。 如: if (x>y) x=y+1; else x-=y; 是正确的语法形式 而 if (x>y) ; x=y+1; else x-=y; 相当于 if (x>y) ; x=y+1; 此处由于 ; 和 x=y+1; 在c语言中是被认为两条语句,应该用{ }括起来,作为一条复合语句(见上面说明1)才正确,否则系统将提示else没有 if 匹配错。(见下面说明3) else x-=y; 3. if 之后可以没有else相匹配,但else不能没有if,即else不能单独使用, 如: if (x>y) x=1; 正确;---无else 而: 。。。 else x--; 错误;---无if进行匹配,else不能单独使用 又如: if(x>y) x++; y--; else --x; ++y; 错误---思考系统提示为何种错误? 4. break 语句只能用于从 switch –case 结构或循环中退出。不能用在其它地方。 5. 判断几个量的大小相互关系时一定不能使用类似如下形式: if (x>y>z) … 必须写成 if (x>y && y>z) … 原因已经讲得很清楚了 6. 在 if (条件) 形式的条件处,条件表达式的形式并非固定为关系表达式或者逻辑表达式,可以是常量、变量、算术表达式等如下均为正确形式: if(6-3)… if(x) …. if(x*x-y*3)… if(x=7) … 系统先计算()内表达式的值,非零认为真即1,0认为假。 特别的对于 if(x=7)…这种形式,系统先把7赋值给变量x,整个赋值表达式的值为7==非零==真==1。 7. 对于循环结构来说,同样while之后,do。。。while之间,for之后只能“管辖”一条语句,当功能需要多条语句时,必须通过{}将其括起来构成一条复合语句构成循环体。反之当循环体只有一条语句时{}可以省略。 8. 对于if。。。else构成的选择结构,while,do。。。while,for构成的循环结构,计算机都会认为是一条语句,而和其下面管辖了多少条语句无关。 如: if (x>y) {t=x;x=y;y=t;} 系统会认为这是一条选择语句。因此如下使用就是正确的: k=0; while(k++) if (x>y) { t=x; x=y; y=t;} 注意:while下面可以不加{ },因为对于系统用来说,现在while下面仅仅“管辖”了一条选择语句。{}可省略。 又如: if(x>3) for(k=0;k<=x;k++) {s=s+k; t=t-k; } 类似的if后面可以不加{},理由同上。 9. 循环如果出现死循环情况可以通过同时按下ctrl和break组合键强行中止循环执行。(针对turbo c中使用) 10. 出现死循环的可能有: <1>循环变量变化方向不是是循环趋于结束(即和循环条件背道而驰) 如 for(k=1;k<=10;k--) 。。。 <2> ; 号位置不正确 如 x=9; while(x>1) ; {x--; s=s+x;} 此时,系统认为while的循环体是一条空语句。 <3>循环条件书写不正确,(恒为真了) 如 原意为 while(x==5) {y++;s=s+y;。。。} 结果少写一个=号while(x=5) {y++;s=s+y;。。。} 则循环条件恒为真(自己思考为什么,参考前面说明。) 11. 对于知道循环次数的循环搭建模式: <1>有一个循环变量,并且在执行循环之前对其初始化 <2>有判断循环是否结束的循环条件 <3>有使循环趋于结束的循环变量变化。 12. 判断一个实数是否为零不能使用如下形式: float x; … while(x==0) {…} 必须使用形如: … while(x<=1e-6) {…}来进行比较判断。 13. break语句结束本循环,continue语句结束本次循环,开始本循环的下一次循环。 比较:若s=0; for(k=3;k<=10;k++) {if (k%3!=0) break; s=s+k; } //运行后s值为3 for(k=3;k<=10;k++) {if (k%3!=0) continue; s=s+k; } //运行后s值为18 考虑为什么。。。。 14. 环嵌套的使用:外层循环m(定值)次,内层循环n(定值)次,则内层循环中的语句供执行m*n次。若内层循环k(k为外层循环变量,k初值为a,终值为b)次,则内层循环中的语句共执行次a+(a+1)+(a+2)+(a+3)+。。。+(b-1)+b 次。 15. 循环嵌套应注意,外层循环变量变化一次,内层循环变量变化一圈(即内层循环全部执行完),外层变量变化永远比内层变量变化慢。 16. 打印图形的通用公式为: <1>两层循环实现,外层变量控制打印多少行,内层变量控制每行打印多少列 <2>内层循环先考虑前导空格打印 <3>再打印相关图形 如若干星号 <4>再打印回车换行符。 参考所给的程序中打印*组成的三角形的例子。 17. 数组的使用应该注意: 如果有 int a[10]; 此处int称为数组的基类型。 表明:数组名为a,数组长度为10,数组中有10个元素,下标由小到大分别是a[0],a[1],a[2]…a[9],数组中每个元素的类型都是整型。数组名a表示数组的首地址,相当于&a[0],即元素a[0]的地址,是常量,程序里不能有a=1000;这样的赋值。 18. 数组初始化,可以在定义数组的同时赋初值 如:int a[10]={1,2}; 给a[0],a[1]赋值1和2其他元素默认0值,注意这种“一次性赋值”的形式只能在数组定义的同时可以,程序中不能出现a[10]=…的样子。 字符数组赋初值时{}内的值应该带上两侧的单引号如: char k[100]={’a’,’b’,’v’,’5’,’*’}; 注意:int a[ ]; 是错误的。 int a[ ]={1,2,3,4};是正确的,计算机可以根据赋初值的个数,确定数组长度。此时等价于:int a[4]={1,2,3,4}; 二维数组定义同时赋初值方法类似: int a[2][3]={{1,2,3},{4,5}};内层的小括号表明给不同的行赋值。也可以写成 int a[2][3]={1,2,3,4,5};此时计算机会自动根据定义的数组行数、列数分配给数组元素对应的值,效果同上。 对于二维数组来说,长度可以为空,不过需要注意的是,只能用在在定义同时赋初值,且第一维为空,第二维不能为空。 如:int a[][]={1,2,3,4,5}; int a[2][]={1,2,3,4,5}; int a[][]={{1,2},{3,4,5}};都是不对的。 正确的方式为: int a[][3]={1,2,3,4,5};相当于 int a[2][3]={1,2,3,4,5};相当于 int a[][3]={{1,2,3},{4,5}}; 不管是几维数组在内存中都是线性存放,因此不要因为定义了二维数组,则输出数组元素时一定会在屏幕上打印出“行列”的二维样式,输出为一行,一列还是方阵、矩阵、三角形,要根据输出语句来控制,通过循环、空格和换行达到需要的效果,跟是否定义为二维数组无关。 19. 数组在使用的时候特别要注意下标越界问题,尤其是一些“隐式”越界不容易被发现,出现越界计算机将会得不到正确结果。 如:int a[10],k,t; for(k=0;k<10;k++) scanf(“%d”,&a[k]); //注意,从循环中退出时k的值其实已经是10了 for(t=k;t>=0;t--)//第一次循环中a[t]即a[10],没有意义。 printf(“%d”,a[t]); 这段程序运行后将多打印出来一个莫名其妙的数据 20.将字符串倒置,下面的代码有什么问题?? main() { char str[14]="abcedfghijklmn"; char a[14]; int i; for(i=0;i<14;i++) a[i]=str[13-i]; printf("%s",a); } 系统运行将会报error C2117: 'abcedfghijklmn' : array bounds overflow错误。 为何报此错误呢? 注意字符串的长度并非是双引号内的字符个数(此题中为14个)而是字符个数加一, 此题为15个,这是因为系统自动要在字符串的末尾添加字符'\0'造成的。 而题目中存放字符串的字符数组str 和a 定义长度为14,不够存放,所以报错误为下标越界! 可以改为 #include <stdio.h> main() { char str[15]="abcedfghijklmn"; char a[15]; int i; for(i=0;i<14;i++) a[i]=str[13-i]; a[i]='\0'; printf("%s",a); } 关于二维数组的行列,需要注意的一点就是:求类似“行最大”或者“列最大”这样的结果时,需要进行 行最大:遍历该行,即确定行下标后,列下标取所有可能。 列最大:遍历该列,即确定列下标后,行下标取所有可能。 for(i=0;i<N;i++) {x[i]=a[i][0]; //---------------注意,此时针对下标为i的每行进行处理,请比较下面另一段代码 for(j=1;j<M;j++) if(x[i]<a[i][j]) x[i] =a[i][j]; //-----这句话的意思是遍历i行所有元素,求出该行最大值,放入x[i]中。 } for(j=0;j<M;j++) {x[j]=a[0][j]; //---------------注意,此时针对下标为j的每列进行处理,请比较上面另一段代码 for(i=1;i<N;i++) if(x[j]<a[i][j]) x[j] =a[i][j]; //-----这句话的意思是遍历j列所有元素,求出该列最大值,放入x[j]中。 } 函数使用中的相关说明 关于函数分类:函数从定义者的角度可以分成:系统函数(库函数)(此时使用时要把相关头文件包含进来)和用户自定义函数;从是否有返回值的角度可以分为:有返回值的函数,无返回值的函数(程序中不带有return语句)。注意:无返回值函数的类型为void,有返回值的函数其返回值类型必须和函数的类型保持一致。函数只能通过return语句带回一个返回值! 如: void a ( int x ) {…..} float b ( int y ) {float c; …… return c;} 关于函数调用: 1. 函数语句调用: 函数名(实参表); 如: m(3,x);此时函数不一定需要有返回值。 2. 表达式调用: 如z=m(x,y); 此时函数需要有返回值作为表达式运算的一部分。 3. 函数作为其他函数的参数调用 如 z=max(max(x,y),z); 此时函数需要有返回值作为其他函数的参数。 关于函数的原型: 如果被调用函数定义书写在调用函数的前面,则调用函数中不需要对其进行声明(该声明及函数原型的声明)。 反之则必须声明。 如:下例中main函数和m函数都调用了a函数,由于a函数对于此二者的相对位置不同。m函数中需要对其进行原型声明,main中则不用 int m( int x, int y ) { float a ( int x );----------原型声明 …. c=a( k ) ; } float a ( int x) {….} main( ) {-----------------无需原型声明 …. c=a( t ) ; } 1、求1+2+3+……….+100。(循环) 答案 #include<stdio.h> void main() { int i,sum=0; for(i=1;i<=100;i++) sum=sum+i; printf("%d",sum); } 2、 求1*2*3*……….*10。(循环) 答案 void main() { int i=0,j=1; for (i=2;i<=10;i++) { j*=i; } printf("%d",j); return 0; } 3、 输入三个数字,输出他们的最大值。(if) 答案 #include<stdio.h> void main() {int a,b,c,d; scanf("%d,%d,%d",&a,&b,&c); d=max(a,b,c); printf("max=%d",d); getch();/*暂停看运行结果*/ } int max(int x,int y,int z) {int u; if(x>=y&&x>=z) u=x; else if(y>=x&&y>=z) u=y; else u=z; return(u); 4.用起泡法对十个数据排序(数组实现) 答案 #include<stdio.h> main ( ) {  int i,j,t;    static int a[10]={5,7,4,2,3,6,1,0,9,8};    for(j=0;j<9;j++)    {   for(i=0;i<9-j;i++)        {  if(a>a)           { t=a;a=a;a=t ;           }        }    } for(i=0;i<10;i++) printf("%2d",a); } 5、输入十个数字,逆序输出。(数组实现) 答案 #include<stdio.h> main() {int a[10],i=0; for(i=0;i<=9;i++) scanf("%f",&a); printf("\n"); for(i=9;i>=0;i--) printf("%f",a); } 6输入两个数,交换他们的值并输出。(元素交换) 答案 #include<stdio.h> int main () {     int m,n,temp; scanf("%d%d",&m,&n); if (m<n) {   temp=m;   m=n;   n=temp; } printf("%d",m);     return 0; } 7.输出9*9乘法表。(双层循环) 答案 #include <stdio.h> void main() { int i=1; for(i; i<=9; i++) {   int j=1;   for(j;j<=i;j++)   {    printf("%d*%d=%d ", i, j, i*j);   }   printf("\n"); } } 8.输入一行字符,将所有的小写字母转换成大写字母,大写字母转换成小写字母,其余字符不变。输出转变后的这行字符。 答案 #include "stdio.h" void main() {     char a[n];     int i;     scanf("%s",a);     printf("大写为:");     for(i=0;i<=n;i++)     {        if(a<='z'&&a>='a')        a=a-32;        printf("%c",a);     }     printf("\n小写为:");     for(i=0;i<=3;i++)     {      a=a+32;         printf("%c",a);     } } 9、 编写一个简单计算器程序,要求能够完成两个数的+,-,*,/四种运算。输出运算式及运算结果。(switch) 6.2 #include"stdio.h" main() {char c;int i=0,j=0,k=0,l=0; while((c=getchar())!=’\n’) {if(c>=65&&c<=90||c>=97&&c<=122) i++; else if(c>=48&&c<=57) j++; else if(c==32) k++; else l++;} printf("i=%d,j=%d,k=%d,l=%d\n",i,j,k,l); } 6.6 #include"math.h" main() {int x=100,a,b,c; while(x>=100&&x<1000) {a=0.01*x;b=10*(0.01*x-a);c=x-100*a-10*b; if(x==(pow(a,3)+pow(b,3)+pow(c,3))) printf("%5d",x);x++;} } 6.7 main() {int m,i,j,s; for(m=6;m<10000;m++) {s=1; for(i=2;i<m;i++) if(m%i==0) s=s+i; if(m-s==0) {printf("%5d its fastors are 1 ",m);for(j=2;j<m;j++) if(m%j==0) printf("%d ",j);printf("\n");} } } 或 main() {int m,i,j,s; for(m=6;m<1000;m++) {s=m-1; for(i=2;i<m;i++) if(m%i==0) s=s-i; if(s==0) {printf("%5d its fastors are 1 ",m);for(j=2;j<m;j++) if(m%j==0) printf("%d ",j);printf("\n");} } } 6.8 main() {int i=1,n;double t,x=1,y=2,s,sum=0; scanf("%ld",&n); while(i<=n) {s=y/x;sum=sum+s;t=y;y=y+x;x=t;i++;} printf("%f\n",sum); } 11,P128  例6.10(译码) #include<stdio.h> void main() { char c; while((c=getchar())!='\n') { c=c+4; if(c>'Z'+4||c>'z') c=c-26; } printf("%c",c); } printf("\n"); } 12,P111  5.5  5.6(switch) 5.5 #include <stdio.h> main() {int x,y; printf("输入x:"); scanf("%d",&x); if(x<1)                         { y=x; printf("x=%3d, y=x=%d\n",x,y); } else if (x<10)                 { y=2*x-1; printf("x=%3d, y=2*x-1=%d\n",x,y); } else                     { y=3*x-11; printf("x=%3d, y=3*x-11=%d\n",x,y); } } 5.6 #include <stdio.h> main() { float score; char grade; case 2: printf("请输入学生成绩:"); scanf("%f",&score); while(score>100||(score<0) { printf("\n输入有误,请重新输入:"); scanf("%f",&score); } switch((int)(score/10)) { case 10: case 9: grade=’A’;break; case 8: grade=’B’;break; case 7: grade=’C’;break; case 6: grade=’D’;break; case 5: case 4: case 3: case 1: case 0: grade=’E’; } printf("成绩是%5.1f,相应的等级是%c。\n",score,grade); } 13,P108  例5.5(一元二次方程求根)  例5.6(求闰年) 5.5 #include<stdio.h> void main() { int year,leap; scanf("%d",&year); if(year%4==0) { if(year%100==0) { if(year%400==0) leap=1; else leap=0; } else leap=1; } else leap=0; if(leap) printf("%d is",year); else printf("%d is not",year); printf("a leap year.\n") } 5.6 14,P31   例2.17   例2.18 2.17 输出50个学生中成绩高于80分者的学号和成绩 2.18 输出2000——2500年每一年是否闰年 #include<stdio.h>     void main()     {         int year;         year=2000;       go: if(((year%4 == 0)&&(year%100 != 0)) || (year%400 == 0))            printf("%d is run nian",year);         if(year<=2500)            year=year++;           if(year>2500)            goto end;               goto go;         end:   getch();        } scanf.... s=0; for(i=1;i<=n;i++) { y=1; for(j=1;j<=i;j++) y=y*j; s=s+y; } printf... 1*(1+2)*(1+2+3)*.....(1+...n) 1!+2!+3!...+n! s=0;y=1; for(i=1;i<=n;i++) {y=y*i; 1!--2!---3!... s=s+y; 0+1!+2!+3!... } //分解质因数 #include <stdio.h> main() {int n,i,j; scanf("%d",&n); for(i=1;i<=n;i++) { for(j=1;j<=n-i+50;j++) printf(" "); for(j=1;j<=2*i-1;j++) printf("*"); printf("\n"); } } #include <stdio.h> void main() {int b[5]; int a,c,d,e,f,g,h,x,i; d=0;e=0;f=0;g=0;h=0; printf("请输入数值(3000<=x<=10000):"); scanf("%d",&x); for(c=1;c<=x-1;c++) if(x%c==0) for(i=2;i<=x/2;i++) b[i]=c; {if(b[i]<=100) d++;} {if(b[i]>100&&b[i]<=300) e++;} {if(b[i]>=301&&b[i]<=500) f++;} {if(b[i]>=501&&b[i]<=1000) g++;} {if(b[i]>=1001&&b[i]<=x/2) h++;} printf("%d %d %d %d %d",d,e,f,g,h); } //p1_1 #include <stdio.h> #include "math.h" #define price 100.0 void main() { float mon,p; //----%f int num; //----%d scanf("%d,%f",&num,&p); mon=price*num; p=fabs(p); printf("money is :%f,p=%f",mon,p); } #include <stdio.h> void main()
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传

当前位置:首页 > 教育专区 > 小学其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服