缓冲区题材,基础试题

by admin on 2019年3月31日

① 、判断字符串,内容是或不是为数字

缓冲区:

缓冲区:

题材讲述
  给定当前的年华,请用英文的读法将它读出来。
  时间用时h和分m表示,在英文的读法中,读二个光阴的方法是:
  假设m为0,则将时读出来,然后加上“o’clock”,如3:00读作“three
o’clock”。
  若是m不为0,则将时读出来,然后将分读出来,如5:30读作“five
thirty”。
  时和分的读法使用的是英文数字的读法,其中0~20读作:
缓冲区题材,基础试题。  0:zero, 1: one, 2:two, 3:three, 4:four, 5:five, 6:six, 7:seven,
8:eight, 9:nine, 10:ten, 11:eleven, 12:twelve, 13:thirteen, 14:fourteen,
15:fifteen, 16:sixteen, 17:seventeen, 18:eighteen, 19:nineteen,
20:twenty。
  30读作thirty,40读作forty,50读作fifty。
  对于超越20小于60的数字,首先读整十的数,然后再加上个位数。如31第①读30再加1的读法,读作“thirty
one”。
  按上边的规则21:54读作“twenty one fifty four”,9:07读作“nine
seven”,0:15读作“zero fifteen”。
输入格式
  输入包罗七个非负整数h和m,表示时间的时和分。非零的数字前从未有过前导0。h小于24,m小于60。
输出格式
  输出时间每日的英文。
样例输入
0 15
缓冲区题材,基础试题。样例输出
zero fifteen

作者们用python;xlrd读Excel内容时,本来只是输入的整数字,平时读出来的是float类型

输入缓冲区

  键盘—》键盘缓冲区—》输入缓冲区—》程序

  大家在键盘上输入的其余东西,会先进入输入缓冲区区域,然后程序从输入缓冲区里把数量一个八个读出来。

输入缓冲区的管理情势:

  先进入的数字会被先读出来(输入缓冲区里把前边的数字读走了,才能读后边的数字)

  1. scanf便是从输入缓冲区里拿数字,假使输入缓冲区的始末和scanf内定的格式类型分歧等,它就不动,不会把输入缓冲区里的别的内容转移走。
  2. 于是你用scanf读叁个%d,输入缓冲区输入3个[a 10],用scanf读取1个平头的时候,它读出来的a发现不是3个整数,它又把那一个a放回去了。下回再读,依旧读的那一个a。a始终堵在缓冲区内,前边的数目10读不到。
  3. 为了缓解那些难题,大家在历次读取四个数额后,把输入缓冲区里的数码全清理掉,作者随便里面有如何,笔者此次读完了随后也随便本次是读到如故没读到,反正自身这一次读完了后来把输入缓冲区全部清理掉,那样的话笔者保险你下1回读的时候是一个新的起先。
  4. 老是读完二个数码后,把输入缓冲区里的数据总体清理掉,保证下一遍再读的时候自然是二个新的始发,这样就不会因为前3次的不当导致后叁次出标题。【清理输入缓冲区的目标:前边的输入出错了,保障不会影响后边的输入】

  每一遍读完四个数量后清理输入缓冲区,保证前面包车型客车输入出错了,不会潜移默化前面包车型客车输入

    scanf(“%*[^\n]”);

    scanf(“%*c”);

  输入缓冲区有这样的八个表征:唯有当其中的数据读走的时候,才会化解这一个数额。

  scanf和缓冲区中的数据类型差异等的时候,便无计可施读走多少,可能会促成死循环。

消除地方难题的法子:

  scanf(“%*[^\n]”);//*大意读到的始末,[^\n]任何非\n的字符;将\n从前的享有字符读走

  scanf(“%*c”);//从缓冲区读取2个字符忽略掉

  补充:scanf调用退步(主要原因:类型不协作)重回垃圾值。

char
ch;

//下边两行能够完全请空缓冲区中的一行内容

scanf(“%*[^\n]”);//先将换行符以前的享有内容都清掉

scanf(“%c”, &ch);//再将\n从输入缓冲区读走

输入缓冲区

  键盘—》键盘缓冲区—》输入缓冲区—》程序(scanf函数)

  我们在键盘上输入的其余事物,会先进入输入缓冲区区域,然后程序从输入缓冲区里把数量三个二个读出来。

 

输入缓冲区的保管方法:

  先进入的数字会被先读出来(输入缓冲区里把前面包车型客车数字读走了,才能读后边的数字)

  1. scanf便是从输入缓冲区里拿数字,尽管输入缓冲区的始末和scanf钦命的格式类型不均等,它就不动,不会把输入缓冲区里的别的内容转移走。
  2. 为此你用scanf读1个%d,输入缓冲区输入三个[a 10],用scanf读取多少个平头的时候,它读出来的a发现不是三个整数,它又把那一个a放回去了。下回再读,依旧读的这么些a。a始终堵在缓冲区内,前边的数量10读不到。
  3. 为了缓解这一个难点,大家在每一回读取1个数额后,把输入缓冲区里的数量全清理掉,小编随便里面有如何,笔者此次读完了未来也随便本次是读到依然没读到,反正自个儿此次读完了随后把输入缓冲区全体清理掉,这样的话小编保证你下贰回读的时候是一个新的开端。
  4. 历次读完3个数码后,把输入缓冲区里的多寡总体清理掉,保证下三遍再读的时候肯定是叁个新的初叶,这样就不会因为前三遍的错误造成后一遍出标题。【清理输入缓冲区的目标:前面包车型客车输入出错了,保证不会潜移默化前面包车型地铁输入】

 

  每一趟读完3个数据后清理输入缓冲区,保障前边的输入出错了,不会潜移默化前边的输入

    scanf(“%*[^\n]”);

    scanf(“%*c”);

 

  输入缓冲区有那样的三个风味:唯有当在那之中的多寡读走的时候,才会免去这一个数量。

  scanf(数据类型)和缓冲区中的数据类型不均等的时候,便不能够读走多少,可能会导致死循环。

解决地方难点的点子:

  scanf(“%*[^\n]”);//*大意读到的始末,[^\n]任何非\n的字符;将\n以前的装有字符读走

  scanf(“%*c”);//从缓冲区读取一个字符忽略掉

  补充:scanf调用失利(主要缘由:类型不般配)再次回到垃圾值。

char
ch;

//上面两行能够完全请空缓冲区中的一行内容

scanf(“%*[^\n]”);//先将换行符从前的装有内容都清掉

scanf(“%c”, &ch);//再将\n从输入缓冲区读走

 

#include<iostream>
#include<string>
using namespace std;
int main()
{
    string m[60];
    m[0]="zero";
    m[1]="one";
    m[2]="two";
    m[3]="three";
    m[4]="four";
    m[5]="five";
    m[6]="six";
    m[7]="seven";
    m[8]="eight";
    m[9]="nine";
    m[10]="ten";
    m[11]="eleven";
    m[12]="twelve";
    m[13]="thirteen";
    m[14]="fourteen";
    m[15]="fifteen";
    m[16]="sixteen";
    m[17]="seventeen";
    m[18]="eighteen";
    m[19]="ninrteen";
    m[20]="twenty";
    m[30]="thirty";
    m[40]="forty";
    m[50]="fifty";
    int h,p;
    while(cin>>h>>p)
    {

    if(h<=20&&p==0)
    {
        cout<<m[h]<<" o'clock"<<endl;
        break;
    }
    if(h<=20&&p<=20)
    {
        cout<<m[h]<<" "<<m[p]<<endl;
        break;
    }
    if(h<=20&&p>20)
    {
        if(p%10==0)
            cout<<m[h]<<" "<<m[p]<<endl;
        else
            cout<<m[h]<<" "<<m[(p/10)*10]<<" "<<m[p%10]<<endl;
        break;
    }
    if(h>20&&p==0)
    {
        cout<<m[(h/10)*10]<<' '<<m[h%10]<<" o'clock"<<endl;
        break;
    }
    if(h>20&&p<=20)
    {
        cout<<m[(h/10)*10]<<" "<<m[h%10]<<" "<<m[p]<<endl;
        break;
    }
    if(h>20&&p>20)
    {
        if(h%10==0)
            cout<<m[(h/10)*10]<<" "<<m[h%10]<<" "<<m[(p/10)*10]<<endl;
        else
            cout<<m[(h/10)*10]<<" "<<m[h%10]<<" "<<m[(p/10)*10]<<" "<<m[p%10]<<endl;
        break;
    }
}

    system("pause");
    return 0;
}```

咱俩须求活动转成整型,意思就是说,读出来的和我们输入的一致,不过,大家不可能一向用int转换,原因吗,我们不能够明确读的各样单元格的值都以数字

scanf的运转原理

  1. scanf假诺发现输入缓冲区中没有东西,就开动录入
  2. scanf发现输入缓冲区中有\n,那么她就会去输入缓冲区取值
  3. 只要发现是团结的菜就会取走放到自个儿盘子里
  4. 若是否祥和的菜,就会友善回去了

bf88必发唯一官网 1

   bf88必发唯一官网 2

    

//检查输入格式是不是科学

#include <stdio.h>

int main() {

int num=0;//开首化清零

printf(“请输入3个数字:”);

while (!scanf(“%d”,&num))
{

scanf(“%*[^\n]”);

bf88必发唯一官网,scanf(“%*c”);

printf(“输入格式错误!\n请输入贰个数字:”);

}

printf(“输入正确!num=%d\n”,num);

return 0;

}

  bf88必发唯一官网 3

  每回使用scanf函数读数据后都亟需清理输入缓冲区!

    

scanf的周转规律

  1. scanf如若发现输入缓冲区中从未东西,就开动录入
  2. scanf发现输入缓冲区中有\n,那么她就会去输入缓冲区取值
  3. 比方发现是团结的菜就会取走放到自个儿盘子里
  4. 一经不是祥和的菜,就会协调回去了

 bf88必发唯一官网 4

   bf88必发唯一官网 5

    

//检查输入格式是或不是正确

#include <stdio.h>

int main() {

    int num=0;//开始化清零

    printf(“请输入3个数字:”);

    while (!scanf(“%d”,&num))
{

        scanf(“%*[^\n]”);

        scanf(“%*c”);

        printf(“输入格式错误!\n请输入二个数字:”);

    }

    printf(“输入正确!num=%d\n”,num);

    return 0;

}

   bf88必发唯一官网 6

  每一趟使用scanf函数读数据后都需求清理输入缓冲区!

    

那么我们和好,定认二个函数如下:

输出缓冲区:

  程序->输出缓冲区->荧屏

  程序的出口能够抵达显示屏的准绳

  输出缓冲区内容呈未来显示屏上的条件:

  1. 遇到\n
  2. 次第甘休
  3. 出口缓冲区满了
  4. 使用fflush强制刷新

输出缓冲区:

  程序(printf函数)->输出缓冲区->显示屏

 

  程序的输出能够抵达显示屏的规则

  输出缓冲区内容体以后显示器上的原则(至少知足三个):

  1. 遇到\n
  2. 次第甘休(函数结束)
  3. 输出缓冲区满了
  4. 选拔fflush(stdout)强制刷新(人工刷新)
def isNumeric(value):
    try:
        tv = float(value)
        return int(tv)
    except ValueError:
        return value

举例:

bf88必发唯一官网 7

举例:

 bf88必发唯一官网 8

 

 

② 、获取当前系统时间

import time

    #获取当前系统时间
    def getCurTime(self):
        curTimeStr = time.strftime('%Y-%m-%d_%H-%M-%S',time.localtime()).decode('utf-8')
        return curTimeStr

 

3、

 

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图