PAT乙级15分题易错题总结

PAT乙级15分题易错题总结

B1026 程序运行时间

输入格式:

输入在一行中顺序给出 2 个整数 C1 和 C2。注意两次获得的时钟打点数肯定不相同,即 C1 < C2,并且取值在 [0,107]。

输出格式:

在一行中输出被测函数运行的时间。运行时间必须按照 hh:mm:ss(即2位的 时:分:秒)格式输出;不足 1 秒的时间四舍五入到秒。

输入样例:

123 4577973

输出样例:

12:42:59

易忽略细节

  • 在计算时,未能正确四舍五入,除100以后余数只要不为零都进位1。//error

B1051 复数乘法

易忽略细节:

在解题过程中,需要判断正负,当-0.01<A<0时,由于只保留两位,所以会按照负数输出为-0.00,而此时,按照正确题意输出格式应为0.00,所以应在判断条件处加一个判断条件if((A+0.09)>0&&A<0) printf("0.00");

同理,负数部分B。当-0.01<B<0时,应该输出+0.00i

1066 图像过滤

#include<iostream>
using namespace std;
int main()
{
    int m,n,a,b,h,temp,i,j;
    scanf("%d %d %d %d %d",&m,&n,&a,&b,&h);
    for(i=0;i<m;++i)
    {
        for(j=0;j<n;++j)
        {
            scanf("%d",&temp);
            if(j!=0)
                printf(" ");
            if(temp>=a&&temp<=b)
                temp=h;
             printf("%03d",temp);
        }
        printf("\n");
    }
    return 0;
}

易忽略细节

  • 在运行时用cin造成运行超时,改成scanf就可以了.**

B1076 Wifi密码

#include<iostream>
using namespace std;
int main()
{
    int n;
    string s;
    cin>>n;
    getchar();
    for(int i=0;i<n;++i)
    {
        getline(cin,s);
        for(int j=2;j<s.length();j+=4)
            if(s[j]=='T')
            {   printf("%d",s[j-2]-'A'+1); break; }
    }
    return 0;
}

易忽略细节

  • 由于cin之后缓冲区还有\n,所以会造成在getline时出错**

B1081 检查密码

#include<iostream>
#include<cctype>
using namespace std;
string s;
void judge(){
    if(s.length()<6)
    {   printf("Your password is tai duan le.\n"); return; }
    int digit=0,alpha=0,flag=0;
    for(int i=0;i<s.length();++i){
    if(isalpha(s[i]))
        alpha=1;
    else if(isdigit(s[i]))
        digit=1;
    else if(s[i]=='.'){
    }
    else{
    flag=1; break;}
    }
    if(flag==1)
        printf("Your password is tai luan le.\n");
    else if(digit==0)
        printf("Your password needs shu zi.\n");
    else if(alpha==0)
        printf("Your password needs zi mu.\n");
    else printf("Your password is wan mei.\n");
}
int main()
{
    int n;
    cin>>n;
    cin.ignore();
    for(int i=0;i<n;++i)
    {
        getline(cin,s);
        judge();
     }
     return 0;
}

易忽略细节

  • 密码中可能会出现空格,而用cin会造成到空格时自动结束读取,出现错误。
  • cin>>n之后缓冲区还有\ngetline读取时会把换行读进去。

原文地址:https://www.cnblogs.com/chenhao777/p/12298534.html

时间: 2024-10-10 23:07:08

PAT乙级15分题易错题总结的相关文章

Java五道输出易错题解析(进来挑战下)

收集了几个易错的或好玩的Java输出题,分享给大家,以后在编程学习中稍微注意下就OK了. 1. 看不见的空格? 下面的输出会正常吗? package basic; public class IntegerTest { public static void main(String[] args) { System.out.println(Integer.parseInt("1")); System.out.println(Integer.parseInt("?2"))

Java五道输出易错题解析(避免小错误)

收集了几个易错的或好玩的Java输出题,分享给大家,以后在编程学习中稍微注意下就OK了. 1. 看不见的空格? 下面的输出会正常吗? package basic; public class IntegerTest { public static void main(String[] args) { System.out.println(Integer.parseInt("1")); System.out.println(Integer.parseInt("2"));

JAVA程序改错 (易错题)

1 JAVA程序改错 2 1. 3 abstract class Name { 4 private String name; 5 public abstract boolean isStupidName(String name) { 6 } 7 } 8 答案: 错.abstract method必须以分号结尾,且不带花括号. 9 2. 10 public class Something { 11 void doSomething () { 12 private String s = ""

[USACO17FEB] Why Did the Cow Cross the Road I P (树状数组求逆序对 易错题)

题目大意:给你两个序列,可以序列进行若干次旋转操作(两个都可以转),对两个序列相同权值的地方连边,求最少的交点数 记录某个值在第一个序列的位置,再记录第二个序列中某个值 在第一个序列出现的位置 ,求逆序对数量即可 本以为是一道逆序对水题,结果被卡了20分.看了题解才恍然大悟,实际上,序列可以旋转 ≠ 序列成环,由于逆序对的特殊性(并不适用于环),故不能把一个序列单独旋转看成它们的相对移动,正着旋转一个序列≠反着旋转另一个序列(更详细证明可以看洛谷) 所以我们要对两个序列再反着进行一次同样的操作

C++笔试易错题集(持续更新)

1.如下代码输出结果是什么? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 #include<stdio.h> char *myString() {     char buffer[6] = {0};     char *s = "Hello World!";     for (int i = 0; i < sizeof(buffer) - 1; i++)     {         buffer[i] = *(s + i);     

易错题

解析:position属性值为absolute.relative或fixed,z-index才有效 解析:在HTML中,控制一个标签背景图像的CSS属性是background-image 解析:abc均可以解决父级元素塌陷的问题,d选项无法解决 解析:此题目考查的是HTML中<form>标签的属性. 为什么是选A,因为form标签表示创建一个表单,name属性表示其名称为form1,method属性表示向服务器端传输数据,其提交方式为post,action属性表示向何处发送表单数据,该题中是向

C/C++程序员面试易错题

c部分::::::::::::::::::::::::::::::::::: 27. 关键字volatile有什么含意? 并给出三个不同的例子.[参考答案]一个定义为volatile的变量是说这变量可能会被意想不到地改变,这样,编译器就不会去假设这个变量的值了.精确地说就是,优化器在用到这个变量时必须每次都小心地重新读取这个变量的值,而不是使用保存在寄存器里的备份.下面是volatile变量的几个例子:1). 并行设备的硬件寄存器(如:状态寄存器)2). 一个中断服务子程序中会访问到的非自动变量

hdu 6149 Valley Numer II (状压DP 易错题)

题目大意:给你一个无向连通图(n<=30),点分为高点和低点,高点数量<=15,如果两个高点和低点都直接连边,那么我们称这三个点形成一个valley,每个点最多作为一个valley的组成部分,求valley的最大数量 高点状压,然后枚举低点,判断这个低点能否影响答案 注意:上一层的值要全都先赋给这一层,再枚举这一层,否则上一层的某些状态可能还没枚举到就枚举这一层了 (比如上一层可行的状态是0110,这一层新来了1001,我们要先把0110和1001赋给这一层,否则我们在从小到大先枚举0110时

C# 易错题整理

1.String类的IndexOf()方法返回的类型是?(选择2项)  BC A.Int16        B.Int32            C.int            D.long 2.下列关于变量定义正确的是:C A. float  f = 3.14; B. bool  b = "false"; C. decimal  d = 12.30M; D. char  c = "ABCD"; 3.执行完语句:int i;  for(i=1;i++<4;)