2011年09月28日 17:54:46
转载自:https://blog.csdn.net/javazejian/article/details/51932554。转载自:https://blog.csdn.net/a19881029/article/details/26348627。2011/07/2516:41 287,832 blog.csdn.net-qi_jianzhou-article-details-649362.mdi。
%a浮点数、十六进制数字和p-记数法(C99)
%A浮点数、十六进制数字和p-记法(C99)
%c 一个字符(char)
%C 一个ISO宽字符
%d有符号十进制整数(int)(%ld、%Ld:长整型数据(long),%hd:输出短整形。)
%e浮点数、e-记数法
%E浮点数、E-记数法
现在有两种解决方法, 第一种就是利用js .tofixed(n) 方法, 直接获取n位小数, 个人觉得这种方法在数据精度上会有一些问题. 如果数据精度要求不高的话 可以使用. 第二种方法就是自己写js 运算方法.。至于2.5还是2.50,要看计算的精度要求,需要1位小数还是2位小数.tl431的精度可以百分位小数.。以163份来自于中国、日本、韩国、不丹、和越南6国的各种类型小豆种质资源的大样本群体为材料,利用27条rapd引物检测该群体得到的261个等位基因数据构建成"总群体",采用完全随机抽样方法,研究不同样本容量(样本位点数)与系统遗传相似系数(jaccard系数)变化的关系,并进一步配置出不同引物数量、多态位点与jaccard系数的变异系数曲线方程,通过分析回归曲线的相应切点,确定在一定精度下适合的引物数量及多态位点数.研究结果表明:不同引物数量之间的jaccard系数的标准差、平均数、变异系数差异极显著. 不同引物数量、不同多态位点与jaccard系数的变异系数、标准差回归方程为y=a+b/x形式,决定系数均在0.95以上. rapd遗传信息分析精度控制在5%~10%时的最适样本容量为15~32条随机引物或120~230个多态性位点.。
%g根据数值不同自动选择%f或%e.
%G根据数值不同自动选择%f或%e.
%i有符号十进制数(与%d相同)
%o无符号八进制整数
%p指针
%s对应字符串char*(%s == %hs == %hS 输出 窄字符)
%S 对应宽字符串WCAHR*(%ws == %S 输出宽字符串)
%u 无符号十进制整数(unsigned int)
%x使用十六进制数字0f的无符号十六进制整数
%X 使用十六进制数字0f的无符号十六进制整数
%% 打印一个百分号
%I64d用于INT64 或者long long
%I64u用于UINT64 或者unsigned long long
%I64x用于64位16进制数据
①%:表示格式说明的起始符号printf格式化输出详细说明,不可缺少。
②-:有-表示左对齐输出,如省略表示右对齐输出。
③0:有0表示指定空位填0,如省略表示指定空位不填。
%f:不指定宽度,整数部分全部输出并输出6位小数。其中number为待计算的数值,num_digits用于指定小数部分的截取精度,取0时不保留小数、取1时保留一位小数(依次类推)。按照 ieee 的规定,单精度浮点数用 32 位表示全体小数,而双精度浮点数用 64 位表示全体小数,而浮点数由符号、尾数、指数和基数组成,所以并不是所有的位数都用来表示小数,符号、指数等也要占据位数,基数不占据位数:。
⑤l或h:l对整型指long型,对实型指double型。h用于将整型的格式字符修正为short型。
---------------------------------------
格式字符
格式字符用以指定输出项的数据类型和输出格式。
①d格式:用来输出十进制整数。有以下几种用法:
%d:按整型数据的实际长度输出。
%md:m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。
②o格式:以无符号八进制形式输出整数。对长整型可以用"%lo"格式输出。同样也可以指定字段宽度用“%mo”格式输出。
例:
main()
{ int a = -1;
printf("%d, %o", a, a);
}
运行结果:-1,177777
程序解析:-1在内存单元中(以补码形式存放)为(1111111111111111)2,转换为八进制数为(177777)8。
同样也可以指定字段宽度用“%mu”格式输出。同样也可以指定字段宽度用"%mx"格式输出。这里要注意一个符号扩展的问题:比如printf格式化输出详细说明,假如我们想打印短整数(short)-1的内存16进制表示形式,在win32平台上,一个short型占2个字节,所以我们自然希望用4个16进制数字来打印它:。
同样也可以指定字段宽度用“%mu”格式输出。同样也可以指定字段宽度用"%mx"格式输出。这里要注意一个符号扩展的问题:比如,假如我们想打印短整数(short)-1的内存16进制表示形式,在win32平台上,一个short型占2个字节,所以我们自然希望用4个16进制数字来打印它:。
⑤c格式:输出一个字符。
⑥s格式:用来输出一个串。有几中用法
%s:例如:printf("%s", "CHINA")输出"CHINA"字符串(不包括双引号)
(1)指定整型数据的输出宽度:%md,若实际位数小于m,则左端补空格,若大于m,则按实际位数输出。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。%m.nf:输出共占m列,其中有n位小数,如数值宽度小于m左端补空格。
%-ms:如果串长小于m,则在m列范围内,字符串向左靠,右补空格。
%m.ns:输出占m列,但只取字符串中左端n个字符。这n个字符输出在m列的右侧,左补空格。
%-m.ns:其中m、n含义同上,n个字符输出在m列范围的左侧,右补空格。如果n>m,则自动取n值,即保证n个字符正常输出。
⑦f格式:用来输出实数(包括单、双精度),以小数形式输出。有以下几种用法:
%f:不指定宽度,整数部分全部输出并输出6位小数。
%m.nf:输出共占m列,其中有n位小数,若数值宽度小于m左端补空格。
%-m.nf:输出共占m列,其中有n位小数,若数值宽度小于m右端补空格。
⑧e格式:以指数形式输出实数。可用以下形式:
%e:数字部分(又称尾数)输出6位小数,指数部分占5位或4位。
%m.ne和%-m.ne:m、n和”-”字符含义与前相同。此处n指数据的数字部分的小数位数,m表示整个输出数据所占的宽度。
⑨g格式:自动选f格式或e格式中较短的一种输出,且不输出无意义的零。
---------------------------------------
关于printf函数的进一步说明:
如果想输出字符"%",则应该在“格式控制”字符串中用连续两个%表示,如:
printf("%f%%", 1.0/3);
输出0.333333%。
---------------------------------------
对于单精度数,使用%f格式符输出时,仅前7位是有效数字,小数6位.
对于双精度数,使用%lf格式符输出时,前16位是有效数字,小数6位.
-----------------------------可变宽度参数
对于m.n的格式还可以用如下方法表示(例)
charch[20];
printf("%*.*s\n",m,n,ch);
前边的*定义的是总的宽度,后边的定义的是输出的个数。分别对应外面的参数m和n 。我想这种方法的好处是可以在语句之外对参数m和n赋值,从而控制输出格式。
本文来自电脑杂谈,转载请注明本文网址:
http://www.pc-fly.com/a/ruanjian/article-107348-1.html
上次来过
一定能达到德艺双馨的境界