南道是过时wwW1000girigiri eye了嘛,怎么输入1000girigiri eyeCoM后点回车没反应

c语言中如何实现输入回车跳出循环_百度知道
c语言中如何实现输入回车跳出循环
#include&stdio.h&
int main()
int a[1000],i=0,j=0;
for(;i&1000;i++)
{a[i]=i+1;}
printf(&%d\n&,a[i]);
} while ((ch=getchar())!='\n');
像上面这个程序,屏幕上不断打印出数字,我要能输...
我有更好的答案
可使用如下方法实现上述操作:char&while(1){&&&&scanf(&%c&,&opt);&&&&if(opt&==&'\n')&&&&{&&&&&&&&&&&&}&&&&//其它操作}
采纳率:44%
因为打印出1后,进入while判断语句,你需要从键盘输入一个值,并且这个值不是回车,才能继续输出 如果需要一直打印,直到你按下回车,那么这需要用到一个函数:kbhit(),这个函数用于“当敲击键盘时执行”,可以用!kbhit()为“当没有敲击键盘时执行”
那我要回车才终止打印的功能要怎么改才能实现呢?
如果需要一直打印,直到你按下回车,那么这需要用到一个函数:kbhit(),这个函数用于“当敲击键盘时执行”,可以用!kbhit()为“当没有敲击键盘时执行”kbhit(),vc++6.0可直接使用,vs2008及更高版本需要包括头文件conio.h
本回答被提问者采纳
i&1000#include&conio.h&#include&i++) {a[i]=i+1;} i=0;
printf(&/ch = getchar();判断是否有按键按下
&#47.h&void main(){
int a[1000],i=0,j=0; for(;,a[i]);
if(i==1000)
if(kbhit())//
ch = getch();%d\n&quot
#include&stdio.h&#include&stdlib.h&int main(){ int a[1000],i=0,j=0;for(i=0;i&1000;i++){a[i]=i+1;}i=0;do{printf(&%d\n&,a[i++]);} while ((ch=getch())!=13);getchar();return 0;}getch()
其他1条回答
为您推荐:
其他类似问题
c语言的相关知识
换一换
回答问题,赢新手礼包
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。电影网_(1000giri)(130201)レズフェティシズム~勉强疲れ;;先生と生徒のストレ种子下载地址有么
答案长度必须超过10个字,请勿发布无效或违法言论。
(共有1个回答)
电影网_(1000giri)(130201)レズフェティシズム~勉强疲れ;;先と徒のストレ种载址:
祝您观影愉快~
[思雨电影网][新电影载玻璃神2HD高清语种载址:复制链接载
[]BF-161 家庭教師翔先生の中出し授業 西野翔种子下载地址:
梁丽版封神榜5[大连电影网]种子下载地址:thunder://QUFodHRwOi8vYWlrYW5keS5vcmcv5qKB5Li954mI5bCB56We5
[114电影网一千零一夜之梦中人DVD中字无水印种子下载地址:请采纳
魅力先生刘天宝14-2.mpg种子下载地址:你要的是这个吧,满意的话记得采纳哦&&
[思雨电影网][更多大片请去赤桥下的暖流DVD中字.wmv种子下载地址:种子链接在此,有问题追问
【生生世世影视】潜艇总动员3:彩虹宝藏1280版BD高清中字种子下载地址:
采纳!做一个有道德的观众
生石花种子批发价格为50元,生石花番杏科生石花属多年生小型多肉植物,茎很短。变态叶肉质肥厚。3-4年生的生石花秋季从对生叶的中间缝隙中开出黄、白、粉等色花朵,多
生石花种子批发价格在?0.12/粒。生石花,又名石头玉,屁股花,属于番杏科、生石花属(Lithopssp.)(或称石头草属)物种的总称,原产非洲南部及西南地区,
你好,这样子的话你可以试试看下面的方法介绍
多晒太阳,注意控水,生长旺季可以见干见湿,其他季节要干些(尤其是冬夏两季),脱皮期间最好断水(小苗第一次脱皮可以少
大家都关注
(C)2017 列表网&琼ICP备号-12&增值电信业务经营许可证B2-&22709人阅读
C/C++(85)
1.printf()简介
printf()是C语言标准库函数,用于将格式化后的字符串输出到标准输出。标准输出,即标准输出文件,对应终端的屏幕。printf()申明于头文件stdio.h。
函数原型:
int printf ( const char * format, ... );
正确返回输出的字符总数,错误返回负值,与此同时,输入输出流错误标志将被置值,可由指示器ferror来检查输入输出流的错误标志。
调用格式:
printf()函数的调用格式为:printf("格式化字符串",输出表列)。
格式化字符串包含三种对象,分别为:
(1)字符串常量;
(2)格式控制字符串;
(3)转义字符。
字符串常量原样输出,在显示中起提示作用。输出表列中给出了各个输出项,要求格式控制字符串和各输出项在数量和类型上应该一一对应。其中格式控制字符串是以%开头的字符串,在%后面跟有各种格式控制符,以说明输出数据的类型、宽度、精度等。
注:本文的所有示例代码均在Linux环境下以g++ 4.4.6编译成64位程序的执行。
2.格式控制字符串详解
printf的格式控制字符串组成如下:
%[flags][width][.prec][length]type
%[标志][最小宽度][.精度][类型长度]类型。
2.1类型(type)
首先说明类型,因为类型是格式控制字符串的重中之重,是必不可少的组成部分,其它的选项都是可选的。type用于规定输出数据的类型,含义如下:
对应数据类型
输出十进制有符号32bits整数,i是老式写法
printf("%i",123);输出123
unsigned int
无符号8进制(octal)整数(不输出前缀0)
printf("0%o",123);输出0173
unsigned int
无符号10进制整数
printf("%u",123);输出123
unsigned int
无符号16进制整数,x对应的是abcdef,X对应的是ABCDEF(不输出前缀0x)
printf("0x%x 0x%X",123,123);输出0x7b 0x7B
float(double)
单精度浮点数用f,双精度浮点数用lf(printf可混用,但scanf不能混用)
printf("%.9f %.9lf",0..);输出0..。注意指定精度,否则printf默认精确到小数点后六位
float(double)
与f格式相同,只不过 infinity 和 nan 输出为大写形式。
例如printf("%f %F %f %F\n",INFINITY,INFINITY,NAN,NAN);输出结果为inf INF nan NAN
float(double)
科学计数法,使用指数(Exponent)表示浮点数,此处”e”的大小写代表在输出时“e”的大小写
printf("%e %E",0..);输出1. 1.
float(double)
根据数值的长度,选择以最短的方式输出,%f或%e
printf("%g %g",0..123);输出1.23e-07 0.123
float(double)
根据数值的长度,选择以最短的方式输出,%f或%E
printf("%G %G",0..123);输出1.23E-07 0.123
字符型。可以把输入的数字按照ASCII码相应转换为对应的字符
printf("%c\n",64)输出A
字符串。输出字符串中的字符直至字符串中的空字符(字符串以空字符’\0‘结尾)
printf("%s","测试test");输出:测试test
宽字符串。输出字符串中的字符直至字符串中的空字符(宽字符串以两个空字符’\0‘结尾)
setlocale(LC_ALL,"zh_CN.UTF-8");wchar_t wtest[]=L"测试Test";printf("%S\n",wtest);输出:测试test
以16进制形式输出指针
printf("%010p","lvlv");输出:0x
什么也不输出。%n对应的参数是一个指向signed int的指针,在此之前输出的字符数将存储到指针所指的位置
int num=0;printf("lvlv%n",&num);printf("num:%d",num);输出:lvlvnum:4
输出字符‘%’(百分号)本身
printf("%%");输出:%
打印errno值对应的出错内容
printf("%m\n");
float(double)
十六进制p计数法输出浮点数,a为小写,A为大写
printf("%a %A",15.15,15.15);输出:0x1.e4ccccccccccdp+3 0X1.E4CCCCCCCCCCDP+3
(1)使用printf输出宽字符时,需要使用setlocale指定本地化信息并同时指明当前代码的编码方式。除了使用%S,还可以使用%ls。
(2)%a和%A是C99引入的格式化类型,采用十六进制p计数法输出浮点数。p计数法类似E科学计数法,但不同。数以0x开头,然后是16进制浮点数部分,接着是p后面是以 2为底的阶码。以上面输出的15.15为例,推算输出结果。15.15转换成二进制为1 01 ...,因为二进制表示数值的离散特点,计算机对于小数有时是不能精确表示的,比如0.5可以精确表示为<span class="MathJax" id="MathJax-Element-1-Frame" tabindex="0" data-mathml="0.12" role="presentation" style="position:">0.120.12,而0.15却不能精确表示。将15.15对应的二进制右移三位,为1.00
...转换对应的十六进制就是0x1.e4ccccccccccd,注意舍入时向高位进了1位。由于右移三位,所以二进制阶码就是3。最后的结果就是0x1.e4ccccccccccdp+3。
(3)格式控制字符串除了指明输出的数据类型,还可以包含一些其它的可选的格式说明,依序有 flags, width, .precision and length。下面一一讲解。
2.2标志(flags)
flags规定输出样式,取值和含义如下:
结果左对齐,右边填空格。默认是右对齐,左边填空格。
输出符号(正号或负号)
输出值为正时加上空格,为负时加上负号
type是o、x、X时,增加前缀0、0x、0X。type是a、A、e、E、f、g、G时,一定使用小数点。默认的,如果使用.0控制不输出小数部分,则不输出小数点。type是g、G时,尾部的0保留。
将输出的前面补上0,直到占满指定列宽为止(不可以搭配使用“-”)
printf("%5d\n",1000);
printf("%-5d\n",1000);
printf("%+d %+d\n",1000,-1000);
printf("% d % d\n",1000,-1000);
printf("%x %#x\n",1000,1000);
printf("%.0f %#.0f\n",1000.0,1000.0)
printf("%g %#g\n",1000.0,1000.0);
printf("%05d\n",1000);
输出结果为:
2.3输出最小宽度(width)
用十进制整数来表示输出的最少位数。若实际位数多于指定的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。width的可能取值如下:
十进制整数
printf("%06d",1000);输出:001000
星号。不显示指明输出最小宽度,而是以星号代替,在printf的输出参数列表中给出
printf("%0*d",6,1000);输出:001000
2.4精度(.precision)
精度格式符以“.”开头,后跟十进制整数。可取值如下:
.precision描述
十进制整数。(1)对于整型(d,i,o,u,x,X),precision表示输出的最小的数字个数,不足补前导零,超过不截断。(2)对于浮点型(a, A, e, E, f ),precision表示小数点后数值位数,默认为六位,不足补后置0,超过则截断。(3)对于类型说明符g或G,表示可输出的最大有效数字。(4)对于字符串(s),precision表示最大可输出字符数,不足正常输出,超过则截断。precision不显示指定,则默认为0
以星号代替数值,类似于width中的*,在输出参数列表中指定精度。
printf("%.8d\n",1000);
printf("%.8f\n",89);
printf("%.8f\n",);
printf("%.8g\n",);
printf("%.8s\n",“abcdefghij”);
输出结果:
注意,在对浮点数和整数截断时,存在四舍五入。
2.5类型长度(length)
类型长度指明待输出数据的长度。因为相同类型可以有不同的长度,比如整型有16bits的short int,32bits的int,也有64bits的long int,浮点型有32bits的单精度float和64bits的双精度double。为了指明同一类型的不同长度,于是乎,类型长度(length)应运而生,成为格式控制字符串的一部分。
因为Markdown表格不支持单元格合并,背景颜色等样式,所以直接引用的表格。
注意:黄色背景行标识的类型长度说明符和相应的数据类型是C99引入的。
示例代码:
printf("%hhd\n",'A');
//输出有符号char
printf("%hhu\n",'A'+128);
//输出无符号char
printf("%hd\n",32767);
//输出有符号短整型short int
printf("%hu\n",65535);
//输出无符号短整型unsigned short int
printf("%ld\n",0x7fffffffffffffff); //输出有符号长整型long int
printf("%lu\n",0xffffffffffffffff); //输出有符号长整型unsigned long int
输出结果:
long int到底是32bits还是64bits跟生成的程序是32bits还是64bits一一对应,如果使用g++编译程序的话,可通过-m32或-m64选项分别生成32bits和64bits的程序。因本人测试代码编译生成的是64bits的程序,所以long int也就是64btis。
3.转义字符
转义字符在字符串中会被自动转换为相应操作命令。printf()使用的常见转义字符如下:
警报(响铃)符
横向制表符
纵向制表符
4.关于printf缓冲
在printf的实现中,在调用write之前先写入IO缓冲区,这是一个用户空间的缓冲。系统调用是软中断,频繁调用,需要频繁陷入内核态,这样的效率不是很高,而printf实际是向用户空间的IO缓冲写,在满足条件的情况下才会调用write系统调用,减少IO次数,提高效率。
printf在glibc中默认为行缓冲,遇到以下几种情况会刷新缓冲区,输出内容:
(1)缓冲区填满;
(2)写入的字符中有换行符\n或回车符\r;
(3)调用fflush手动刷新缓冲区;
(4)调用scanf要从输入缓冲区中读取数据时,也会将输出缓冲区内的数据刷新。
可使用setbuf(stdout,NULL)关闭行缓冲,或者setbuf(stdout,uBuff)设置新的缓冲区,uBuff为自己指定的缓冲区。也可以使用setvbuf(stdout,NULL,_IOFBF,0);来改变标准输出为全缓冲。全缓冲与行缓冲的区别在于遇到换行符不刷新缓冲区。
printf在VC++中默认关闭缓冲区,输出时会及时的输到屏幕<span class="MathJax" id="MathJax-Element-2-Frame" tabindex="0" data-mathml="[3]" role="presentation" style="position:">[3][3]。如果显示开启缓冲区,只能设置全缓冲。因为微软闭源,所以无法研究printf函数的实现源码。
Linux和Windows下的缓冲区管理可见:。
5.printf与wprintf不能同时使用
该小结写在日。两年后的今日,在网上苦苦搜索寻求答案,终于解决了之前的疑惑。
在输出宽字符串时,发现将printf和wprintf同时使用时,则后使用的函数没有输出。这里建议不要同时使用printf和wprintf,以免发生错误。
printf和wprintf不能同时输出宽字符串的示例代码如下:
#include &stdio.h&
#include &wchar.h&
#include &locale.h&
int main(int argc,char* argv[]){
char test[]="测试Test";
setlocale(LC_ALL,"zh_CN.UTF-8");
wchar_t wtest[]=L"0m~K0m~UTest";
printf("printf:%S\n",wtest);
wprintf(L"wprintf:%S\n",wtest);
上面的代码中语句1和语句二不能同时存在,否则只能正常输出第一个。也不知道在Windows平台是否也存在这种问题,有兴趣的读者可以尝试一下。关于原因,GNU官方文档中有明确说明不能同时使用printf与wprintf,参见,内容如下:
It is important to never mix the use of wide and not wide operations on a stream. There are no diagnostics issued. The application behavior will simply be strange or the application will simply crash.
这里是因为输出流在被创建时,不存在流定向,一旦使用了printf(多字节流)或wprintf(宽字符流)后,就被设置为对应的流定向,且无法更改。可以使用如下函数获取当前输出流的流定向。
int fwide (FILE* stream, int mode);
int ret=fwide(stdout,0);
通过fwide可以设置当前流定向,前提是未有任何的I/O操作,也就是当前流尚未被设置任何流定向。顺带吐槽一下,不知为何标准库函数fwide为何实现的如此受限。具体操作如下:
fwide(stdout,-1);
fwide(stdout,1);
既然GNU C存在这个问题,那该如何解决呢?这里有两种办法:
(1)统一使用一种函数。
wprintf(L"%s","a\n");
wprintf(L"b\n");
printf("a\n");
printf("%ls\n",L"b");
(2)使用freopen清空流定向。
FILE* pFile=freopen("/dev/tty","w",stdout);
wprintf(L"wide freopen succeeded\n");
pFile=freopen("/dev/tty","w",stdout);
printf("narrow freopen succeeded\n");
上面可以让printf与wprintf同时使用。
耗时将近两年,终于完成了此篇看似基础,但却纷繁复杂的printf()用法。由于时间和个人水平有限,文章不足之处在所难免,也请读者批评指正,不甚感激。
文章:80篇
阅读:285395
阅读:25857
阅读:34817
阅读:63614
文章:39篇
阅读:20407
阅读:8713
文章:12篇
阅读:8240excel单元格输入1000,回车后自动变成10是怎么回事,以前没有出现这个问题输入1000就是1000_百度知道
excel单元格输入1000,回车后自动变成10是怎么回事,以前没有出现这个问题输入1000就是1000
我有更好的答案
hiphotos.baidu.com/zhidao/wh%3D450%2C600/sign=b9e8b7e4c88426fdcceff8/203fb80e7bec54e75e3b504ec26ae9://a,!0&nbsp当单元格格式设置为“自定义”类型为& 0; 时,输入数值与显示数值相差100倍。详见附图示例
采纳率:79%
来自团队:
Excel选项里面,有一个“自动小数位数”参数。你可能无意间设置了“自动2位小数”。如是,关闭即可!
本回答被提问者采纳
为您推荐:
其他类似问题
excel的相关知识
&#xe675;换一换
回答问题,赢新手礼包&#xe6b9;
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。噢哦,这个页面找不到了
下载作业帮可以找到更多答案

我要回帖

更多关于 girigiri爱 的文章

 

随机推荐