要点1:数据类型
char 1; short 2; int float 4 ;double 8; long 应与系统的位数有关;
要点2;转换格式控制:
printf("%04d",12);//不足位补0;
printf("%-4d",14);//左对齐
printf("%m.nf",123.456);
其中m是输出宽度,n是精度,f是格式化控制符
m指定的是输出数字字符串的最小长度,比如你输出
printf("%2.3f" , 123.456 ); //由于实际输出的数字123.456共有7个字符,大于2个字符数量,所以这里的2其实实际上没起到什么作用,不过如果你printf("%8.3f" , 123.456 );,8-7=1,那么结果将在数字前面补一个空格字符,使用printf( "%08.3f" , 123.456 );则是补一个字符'0'
所以e如果存在于被输出的数字串里的话(比如使用%e),它也是要占用m的计数的,包括小数点。
n则是指定输出精度,也就是小数点后保留几位,默认不指定.n的时候printf会自动调整输出到默认精确位,如果指定了n的话,printf则把数字保留小数点后n位输出。
所以printf( "%f", 123.456 );如果输出123.456000的话,那么printf("%.2f", 123.456 );则输出123.46,
要点3:printf();转换符与对应类型
转化符 类型
%d int
%sd short
%c char
%f float double
%ld long
要点4:辗转相除法简单的想法
设两数为a、b(a>b),求a和b最大公约数(a,b)的步骤如下:用b除a,得a÷b=q......r1(0≤r1)。若r1=0,则(a,b)=b;若r1≠0,则再用r1除b,得b÷r1=q......r2 (0≤r2).若r2=0,则(a,b)=r1,若r2≠0,则继续用r2除r1,……如此下去,直到能整除为止。其最后一个非零除数即为(a,b)。