其他分享
首页 > 其他分享> > 实验二10.31

实验二10.31

作者:互联网

//ex1
#include <stdio.h>
#include <stdlib.h>
int main()
{
    int a = 5, b =7 , c = 100, d, e, f;

    d = a / b * c;
    e = a * c / b;
    f = c / b * a;
    printf("d=%d, e=%d, f=%d\n", d, e, f);
    system("pause");

    return 0;
}

line6运算:d=①a/b=5/7=0            ②0*c=0*100=0        ∴d=0

line7运算:e=①a*c=5*100=500  ②500/b=500/7=71   ∴e=71

line8运算:f=①c/b=100/7=14      ②14*a=14*5=70       ∴f=70

结果不同原因:1)abcdef均为int型,所得商均为整数  2)运算顺序不同  3)运算方向为从左到右

// ex2

#include <stdio.h>
int main() 
{
    int x = 1234;
    float f = 123.456;
    double m = 123.456;
    char ch = 'a';
    char a[] = "Hello, world!";
    int y = 3, z = 4;

    printf("%d %d\n", y, z);
    printf("y=%d, z=%d\n", y, z);
    printf("%7.6d,%2d\n", x, x);
    printf("%f, %8f, %8.1f, %0.2f, %.2e\n", f, f, f, f, f);
    printf("%lf\n", m);
    printf("%3c\n", ch);
    printf("%s\n%15s\n%10.5s\n%2.5s\n%.3s\n", a, a, a, a, a);

    return 0;
}

 格式符用法总结(%[<修饰符>]<格式字符>):

1)%d

①%d→按十进制整数输出

②%md→当数据长度x≥m时,无论m取小数、负数、0等数据皆输出原数据;

                  当x<m且m为整数时,m限制数据总长度,不够时左补空格

2)%f

①%f→按单精度浮点数输出,无修饰符时小数按6位小数输出;

注:实验中输出123.456001而不是123.456000,因为在计算机内部数据以二进制表示,输出时要经过十进制到二进制的转换,小数部分×2直到结果为0或指定精度时结束,不是所有小数都能或能在指定精度前达到结果为1,所以产生数据损失,如果要求前六位都是完全精确的值,可以使用double双精度浮点,输出用%lf而不是%f

②%mf→按单精度浮点数输出,数据长度(数据长度为整数位数+小数6位+小数点1位)<m时,左补空格,否则按实际输出,小数按6位小数输出;

③%m.nf→按单精度浮点数输出,数据长度(数据长度为整数位数+小数n位+小数点1位)<m时,左补空格,否则按实际输出,小数按n位输出(四舍五入);

④%.nf→按浮点数输出,对整数部分长度无要求按实际输出,小数部分保留n位(四舍五入);

⑤%.nef→整个数据留小数点后n位,且以指数形式输出;

⑥%lf→按双精度浮点数输出,无其他修饰符时小数按6位小数输出

3)%c

①%c→按字符输出;

②%mc→按m位字符输出;

4)%s

①%s→输出字符串;

②%ms→输出占m位的字符串,数据长度<m时,左补空格,否则按实际输出;

③%m.ns→保留n位字符串,然后输出占m位的字符串,n<m时,左补空格,否则按实际输出

// ex3
#include <stdio.h>
int main()
{ double x, y; char c1, c2, c3; int a1, a2, a3; scanf_s("%d%d%d", &a1, &a2, &a3); printf("a1=%d,a2=%d,a3=%d\n", a1, a2, a3); scanf_s("%c%c%c", &c1,2, &c2,2, &c3,2); printf("c1=%c,c2=%c,c3=%c\n", c1, c2, c3); scanf_s("%lf,%lf", &x, &y); printf("x=%f,y=%lf\n", x, y); return 0; }

 

// ex4-判断字符类型 
#include <stdio.h>
int main()
{ char x; x = getchar(); if (x>=48&&x<=57) printf("%c是数字字符\n", x); else if (x>=65&&x<=122) printf("%c是英文字母\n", x); else printf("%c是其它字符\n", x); return 0; }

 

 

 

 

// ex5
#include <stdio.h>
int main() 
{
    char ans1, ans2;

    printf("复习了没? (输入y或Y表示复习了,输入n或N表示没复习) :  ");
    ans1 = getchar();

    getchar(); 

    printf("\n动手敲代码了没? (输入y或Y表示敲了,输入n或N表示木有敲) :  ");
    ans2 = getchar();

    if (ans1=='y'||ans1=='Y'&&ans2=='y'||ans2=='Y')
        printf("\n罗马不是一天建成的:)\n");
    else
        printf("\n罗马不是一天毁灭的。。。\n");

    return 0;
}

 

getchar();单独成行原因:消除缓冲区的字符

比如输入ans1=getchar()后按下了回车,此时回车符会存在于缓冲区中,
这时继续输输入ans2=getcha()的时候
此时这个gets()会把那个缓冲区的回车读入到ans2(如下图)


ans2还未输入就自动判定为回车且输出了结果。

所以在之前,我们可以用单独的getchar()接收掉这个回车符,那么就可以正确输入了

 

//ex6-等比数列前n项和
#include <stdio.h>
#include <math.h>
int main()
{
    int n, sum;
    
    printf("输入1-10之间的整数n\n");
    
    scanf_s("%d", &n);
    
    sum = pow(2, n)+1;

    printf("当n=%d时,sum=%d",n,sum);
    
        
    
        return 0;

}

 

实验总结:遇到bug一定要深究,彻底搞懂,不留隐患。

 

标签:输出,10.31,int,getchar,实验,printf,include,小数
来源: https://www.cnblogs.com/yhy2001/p/13905540.html