1.检测用户错误输入(4分)
题目内容:
根据scanf()的返回值判断scanf()是否成功读入了指定的数据项数,使程序在用户输入123a时,能输出如下运行结果:
123a
Input error!
输入格式: "%d %d"
输出格式:
如果成功读入指定的数据项数,输出格式为:"a = %d, b = %d\n" (注意:等号的两边各有一个空格)
输入非法数据,输出格式为:"Input error!"
为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。
时间限制:500ms内存限制:32000kb
#include <stdio.h>
int main()
{
int a,b,c;
c = scanf("%d %d",&a,&b);
if(c==2)
printf("a = %d, b = %d\n",a,b);
else
printf("Input error!");
return 0;
}
2,闰年判断(6分)
题目内容:
从键盘任意输入一个公元年份(大于等于1),判断它是否是闰年。若是闰年输出“Yes”,否则输出“No”。要求对输入数据进行合法性判断。
已知符合下列条件之一者是闰年:
(1)能被4整除,但不能被100整除;
(2)能被400整除。
运行结果示例1:
2015
No
运行结果示例2:
2016
Yes
运行结果示例3:
-123
Input error!
运行结果示例4:
a
Input error!
输入格式: "%d"
输出格式:
是闰年,输出:"Yes\n"
不是闰年,输出:"No\n"
输入数据不合法,输出:"Input error!\n"
为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。
时间限制:500ms内存限制:32000kb
#include <stdio.h>
#include <stdlib.h>
int main()
{
int n=0;
scanf("%d",&n);
if(n>0)
{
if((n%4==0&&n%100!=0)||(n%400==0))
printf("Yes\n");
else
printf("No\n");
}
else
printf("Input error!\n");
return 0;
}
3.程序改错v1.0(7分)
题目内容:
下面代码的功能是将百分制成绩转换为5分制成绩,具体功能是:如果用户输入的是非法字符或者不在合理区间内的数据(例如输入的是a,或者102,或-45等),则程序输出 Input error!,否则将其转换为5分制输出。目前程序存在错误,请将其修改正确。并按照下面给出的运行示例检查程序。
#include<stdio.h> int main() { int score; char grade; printf("Please input score:"); scanf("%d", &score); if (score < 0 || score > 100) printf("Input error!\n"); else if (score >= 90) grade = 'A’; else if (score >= 80) grade = 'B'; else if (score >= 70) grade = 'C'; else if (score >= 60) grade = 'D'; else grade = 'E'; printf("grade:%c\n", grade); return 0; }
程序运行结果示例1:
Please input score:
-1
Input error!
程序运行结果示例2:
Please input score:
95
grade: A
程序运行结果示例3:
Please input score:
82
grade: B
程序运行结果示例4:
Please input score:
72
grade: C
程序运行结果示例5:
Please input score:
66
grade: D
程序运行结果示例6:
Please input score:
32
grade: E
程序运行结果示例7:
Please input score:
127
Input error!
输入提示信息:"Please input score:\n"
输入格式: "%d"
输出格式:
用户输入存在错误时,输出提示信息:"Input error!\n"
输出格式:"grade: %c\n" (注意:%c前面有一个空格)
为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。
时间限制:500ms内存限制:32000kb
#include <stdio.h>
int main()
{
printf("Please input score:\n");
int score,s;
char grade;
scanf("%d",&score);
s=score/10;
switch(s)
{
case 10:
case 9: grade='A'; printf("grade: %c\n",grade);break;
case 8: grade='B'; printf("grade: %c\n",grade);break;
case 7: grade='C'; printf("grade: %c\n",grade);break;
case 6: grade='D'; printf("grade: %c\n",grade);break;
case 5:
case 4:
case 3:
case 2:
case 1:grade='E';printf("grade: %c\n",grade);break;
default:printf("Input error!\n");
}
return 0;
}
4.字符类型判断(4分)
题目内容:
从键盘键入任意一个字符,判断该字符是英文字母(不区分大、小写)、数字字符还是其它字符。
若键入字母,则屏幕显示 It is an English character.;若键入数字则屏幕显示It is a digit character. ;若输入其它字符,则屏幕显示:It is other character.
程序的运行示例1:
Input simple:
b
It is an English character.
程序的运行示例2:
Input simple:
6
It is a digit character.
程序的运行示例3:
Input simple:
*
It is other character.
程序的运行示例4:
Input simple:
A
It is an English character.
输入信息提示:"Input simple:\n"
输入格式: "%c"
输出格式:
英文字符的输出格式:"It is an English character.\n"
数字的输出格式:"It is a digit character.\n"
其它字符的输出格式:"It is other character.\n"
为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。
时间限制:500ms内存限制:32000kb
#include <stdio.h>
int main()
{
printf("Input simple:\n");
char a;
scanf("%c",&a);
if((a>='a'&&a<='z')||(a>='A'&&a<='Z'))
printf("It is an English character.\n");
else if(a>='0'&&a<='9')
printf("It is a digit character.\n");
else
printf("It is other character.\n");
return 0;
}
5.快递费用计算(7分)
题目内容:
上海市的某快递公司根据投送目的地距离公司的远近,将全国划分成5个区域:
0区 |
1区 |
2区 |
3区 |
4区 |
同城 |
临近两省 |
1500公里(含)以内 |
1500——2500公里 |
2500公里以上 |
上海 |
江苏,浙江 |
北京,天津,河北,辽宁,河南,安微,陕西,湖北,江西,湖南,福建,广东,山西。 |
吉林,辽宁,甘肃,四川,重庆,青海,广西,云南,海南,内蒙古,黑龙江,贵州。 |
新疆,西藏。 |
快递费按邮件重量计算,由起重费用、续重费用两部分构成:
(1) 起重(首重)1公斤按起重资费计算(不足1公斤,按1公斤计算),超过首重的重量,按公斤(不足1公斤,按1公斤计算)收取续重费;
(2) 同城起重资费10元,续重3元/公斤;
(3) 寄往1区(江浙两省)的邮件,起重资费10元,续重4元;
(4) 寄往其他地区的邮件,起重资费统一为15元。而续重部分,不同区域价格不同:2区的续重5元/公斤,3区的续重6.5元/公斤,4区的续重10元/公斤。
编写程序,从键盘输入邮件的目的区域编码和重量,计算并输出运费,计算结果保留2位小数。程序中所有浮点数的数据类型均为float。
提示:续重部分不足一公斤,按1公斤计算。因此,如包裹重量2.3公斤:1公斤算起重,剩余的1.3公斤算续重,不足1公斤按1公斤计算,1.3公斤折合续重为2公斤。如果重量应大于0、区域编号不能超出0-4的范围。
程序运行结果示例1:
4,4.5
Price: 55.00
程序运行结果示例2:
5,3.2
Error in Area
Price: 0.00
输入格式:
用逗号分隔的两个数字,第一个表示区域、第二个是重量:"%d,%f"
输出格式:
价格的输出格式:"Price: %5.2f\n"
区域错误的提示信息:"Error in Area\n"
为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。
时间限制:500ms内存限制:32000kb
#include <stdio.h>
int main()
{
float sum,a,b,weigh;
int qu;
scanf("%d,%f",&qu,&weigh);
if(qu<0||qu>=5)
printf("Error in Area\n");
switch(qu)
{
case 0:if(weigh<=1) sum=10;
else sum=10+(int)weigh*3;break;
case 1:if(weigh<=1) sum=10;
else sum=10+(int)weigh*4;break;
case 2:if(weigh<=1) sum=15;
else sum=15+(int)weigh*5;break;
case 3:if(weigh<=1) sum=15;
else sum=15+(int)weigh*6.5;break;
case 4:if(weigh<=1) sum=15;
else sum=15+(int)weigh*10;break;
}
printf("Price: %5.2f\n",sum);
return 0;
}
6.数位拆分v2.0(4分)
题目内容:
从键盘上输入一个4位数的整数n,编写程序将其拆分为两个2位数的整数a和b,计算并输出拆分后的两个数的加、减、乘、除和求余运算的结果。例如n=-4321,设拆分后的两个整数为a,b,则a=-43,b=-21。除法运算结果要求精确到小数点后2位,数据类型为float。求余和除法运算需要考虑除数为0的情况,即如果拆分后b=0,则输出提示信息"The second operater is zero!"
程序的运行结果示例1:
Please input n:
1200
12,0
sum=12,sub=12,multi=0
The second operator is zero!
程序的运行结果示例2:
Please input n:
-2304
-23,-4
sum=-27,sub=-19,multi=92
dev=5.75,mod=-3
输入提示信息:"Please input n:\n"
输入格式: "%d"
输出格式:
拆分后的两个整数的输出格式:"%d,%d\n"
加法、减法、乘法的输出格式:"sum=%d,sub=%d,multi=%d\n"
除法和求余的输出格式:"dev=%.2f,mod=%d\n"
除数为0的提示信息:"The second operator is zero!\n"
为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。
时间限制:500ms内存限制:32000kb
#include <stdio.h>
int main()
{
printf("Please input n:\n");
int n,a,b,sum,sub,multi,mod;
float dev;
scanf("%d",&n);
a=n/100;
b=n%100;
sum=a+b;
sub=a-b;
multi=a*b;
printf("%d,%d\n",a,b);
printf("sum=%d,sub=%d,multi=%d\n",sum,sub,multi);
if(b!=0)
{
dev=(float)a/b;
mod=a%b;
printf("dev=%.2f,mod=%d\n",dev,mod);
}
else printf("The second operator is zero!\n");
return 0;
}
7.出租车计价(4分)
题目内容:
已知某城市普通出租车收费标准为:起步里程为3公里,起步费为8元,10公里以内超过起步里程的部分,每公里加收2元,超过10公里以上的部分加收50%的回空补贴费,即每公里3元。出租车营运过程中,因堵车和乘客要求临时停车等客的,按每5分钟加收2元
计算,不足5分钟的不计费。从键盘任意输入行驶里程(精确到0.1公里)和等待时间(精确到分钟),请编程计算并输出乘客应支付的车费,对结果进行四舍五入,精确到元。
程序运行结果示例1:
Input distance and time:2,2
fee = 8
程序运行结果示例2:
Input distance and time:5,5
fee = 14
程序运行结果示例3:
Input distance and time:12,15
fee = 34
程序运行结果示例4:
Input distance and time:20,0
fee = 52
输入提示信息:"Input distance and time:"
输入格式:
用逗号分隔的两个数字,第一个表示距离、第二个表示时间:"%f,%d"
输出格式:"fee = %.0f\n" (注意:等号的两边各有一个空格)
为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。
时间限制:500ms内存限制:32000kb
#include <stdio.h>
int main()
{
printf("Input distance and time:");
int t;
float d,sum,sum1;
scanf("%f,%d",&d,&t);
if(d<=3)
sum1=8;
else if(d<=10)
sum1=8+(d-3)*2;
else sum1=22+(d-10)*3;
sum=sum1+(t/5)*2;
printf("fee = %.0f\n",sum);
return 0;
}
8.数据区间判断(6分)
题目内容:
从键盘输入一个int型的正整数n(已知:0<n<10000),编写程序判断n落在哪个区间。如果用户输入的数据不在指定的范围里,程序输出 "error!"。例如,输入265,则该数属于区间 100-999。
程序运行结果示例1:
Please enter the number:
2563
2563: 1000-9999
程序运行结果示例2:
Please enter the number:
156
156: 100-999
程序运行结果示例3:
Please enter the number:
36
36: 10-99
程序运行结果示例4:
Please enter the number:
3
3: 0-9
程序运行结果示例5:
Please enter the number:
10923
error!
输入提示信息:"Please enter the number:\n"
输入错误提示信息:"error!\n"
输入格式: "%d"
输出格式:
输出的区间判断:
"%d: 1000-9999\n"
"%d: 100-999\n"
"%d: 10-99\n"
"%d: 0-9\n"
为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。
时间限制:500ms内存限制:32000kb
#include <stdio.h>
int main()
{
printf("Please enter the number:\n");
int n,a;
scanf("%d",&n);
if(n>0&&n<10)
printf("%d: 0-9\n",n);
else if(n>=10&&n<100)
printf("%d: 10-99\n",n);
else if(n>=100&&n<1000)
printf("%d: 100-999\n",n);
else if(n>=1000&&n<10000)
printf("%d: 1000-9999\n",n);
else
printf("error!\n");
return 0;
}
9.计算一元二次方程的根v2.0(4分)
题目内容:
根据下面给出的求根公式,计算并输出一元二次方程
的两个实根,要求精确到小数点后4位。其中a,b,c的值由用户从键盘输入。如果用户输入的系数不满足求实根的要求,输出错误提示 "error!"。程序中所有的数据类型均为float。
程序运行结果示例1:
Please enter the coefficients a,b,c:
1,2,1
x1=-1.0000, x2=-1.0000
程序运行结果示例2:
Please enter the coefficients a,b,c:
2,6,1
x1=-0.1771, x2=-2.8229
程序运行结果示例3:
Please enter the coefficients a,b,c:
2,1,6
error!
输入提示信息:"Please enter the coefficients a,b,c:\n"
输入格式: "%f,%f,%f"
输出格式: "x1=%7.4f, x2=%7.4f\n"
如果输入的系数不满足求实根的要求,输出错误提示信息:"error!\n"
为避免出现格式错误,请直接拷贝粘贴题目中给的格式字符串和提示信息到你的程序中。
时间限制:500ms内存限制:32000kb
#include <stdio.h>
#include <math.h>
int main()
{
printf("Please enter the coefficients a,b,c:\n");
float a,b,c,dert,x1,x2;
scanf("%f,%f,%f",&a,&b,&c);
dert=b*b-4*a*c;
if(dert<0)
printf("error!\n");
else
{
x1=-b/(2*a)+sqrt(dert)/(2*a);
x2=-b/(2*a)-sqrt(dert)/(2*a);
printf("x1=%7.4f, x2=%7.4f\n",x1,x2);
}
return 0;
}
文章浏览阅读1.6w次,点赞8次,收藏41次。生活中我们无时不刻不都要在网站搜索资源,但就是缺少一个趁手的资源搜索网站,如果有一个比较好的资源搜索网站可以帮助我们节省一大半时间!今天小编在这里为大家分享5款超厉害的资源搜索网站,每一款都可以让你的资源丰富精彩!网盘传奇一款最有效的网盘资源搜索网站你还在为找网站里面的资源而烦恼找不到什么合适的工具而烦恼吗?这款网站传奇网站汇聚了4853w个资源,并且它每一天都会持续更新资源;..._最全资源搜索引擎
文章浏览阅读4.5k次,点赞5次,收藏18次。阅读测试程序,设计一个Book类。函数接口定义:class Book{}该类有 四个私有属性 分别是 书籍名称、 价格、 作者、 出版年份,以及相应的set 与get方法;该类有一个含有四个参数的构造方法,这四个参数依次是 书籍名称、 价格、 作者、 出版年份 。裁判测试程序样例:import java.util.*;public class Main { public static void main(String[] args) { List <Book>_6-1 book类的设计java
文章浏览阅读613次,点赞28次,收藏27次。相比于以前的传统手工管理方式,智能化的管理方式可以大幅降低学校的运营人员成本,实现了校园导航的标准化、制度化、程序化的管理,有效地防止了校园导航的随意管理,提高了信息的处理速度和精确度,能够及时、准确地查询和修正建筑速看等信息。课题主要采用微信小程序、SpringBoot架构技术,前端以小程序页面呈现给学生,结合后台java语言使页面更加完善,后台使用MySQL数据库进行数据存储。微信小程序主要包括学生信息、校园简介、建筑速看、系统信息等功能,从而实现智能化的管理方式,提高工作效率。
传统上用户登陆状态会以 Session 的形式保存在服务器上,而 Session ID 则保存在前端的 Cookie 中;而使用 JWT 以后,用户的认证信息将会以 Token 的形式保存在前端,服务器不需要保存任何的用户状态,这也就是为什么 JWT 被称为无状态登陆的原因,无状态登陆最大的优势就是完美支持分布式部署,可以使用一个 Token 发送给不同的服务器,而所有的服务器都会返回同样的结果。有状态和无状态最大的区别就是服务端会不会保存客户端的信息。
文章浏览阅读784次。发表于10小时前| 2674次阅读| 来源TechCrunch| 19 条评论| 作者Jon EvansiOSAndroid应用开发产品编程语言JavaObjective-C摘要:即便Android市场份额已经超过80%,对于开发者来说,使用哪一个平台做开发仍然很难选择。本文从开发环境、配置、UX设计、语言、API、网络、分享、碎片化、发布等九个方面把Android和iOS_ios 开发角度
搜索引擎的发展历史可以追溯到20世纪90年代初,随着互联网的快速发展和信息量的急剧增加,人们开始感受到了获取和管理信息的挑战。这些阶段展示了搜索引擎在技术和商业模式上的不断演进,以满足用户对信息获取的不断增长的需求。
文章浏览阅读990次。对象特性是指控制对象的输出参数和输入参数之间的相互作用规律。放大系数K描述控制对象特性的静态特性参数。它的意义是:输出量的变化量和输入量的变化量之比。时间常数T当输入量发生变化后,所引起输出量变化的快慢。(动态参数) ..._控制对象特性
文章浏览阅读5.7w次,点赞50次,收藏276次。FRP搭建内网穿透1.概述:frp可以通过有公网IP的的服务器将内网的主机暴露给互联网,从而实现通过外网能直接访问到内网主机;frp有服务端和客户端,服务端需要装在有公网ip的服务器上,客户端装在内网主机上。2.简单的图解:3.准备工作:1.一个域名(www.test.xyz)2.一台有公网IP的服务器(阿里云、腾讯云等都行)3.一台内网主机4.下载frp,选择适合的版本下载解压如下:我这里服务器端和客户端都放在了/usr/local/frp/目录下4.执行命令# 服务器端给执_locyanfrp
文章浏览阅读687次。题目:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=93745#problem/A题意:给出r*c的01矩阵,可以翻转格子使得0表成1,1变成0,求出最小的步数使得每一行中1的个数相等,每一列中1的个数相等。思路:网络流。容量可以保证每一行和每一列的1的个数相等,费用可以算出最小步数。行向列建边,如果该格子是_uva12534
文章浏览阅读504次。1、Let's Encrypt 90天,支持泛域名2、Buypass:https://www.buypass.com/ssl/resources/go-ssl-technical-specification6个月,单域名3、AlwaysOnSLL:https://alwaysonssl.com/ 1年,单域名 可参考蜗牛(wn789)4、TrustAsia5、Alpha..._csdn alphassl免费申请
文章浏览阅读1.6k次。测试算法的性能 很多时候我们需要对算法的性能进行测试,最简单的方式是看算法在特定的数据集上的执行时间,简单的测试算法性能的函数实现见testSort()。【思想】:用clock_t计算某排序算法所需的时间,(endTime - startTime)/ CLOCKS_PER_SEC来表示执行了多少秒。【关于宏CLOCKS_PER_SEC】:以下摘自百度百科,“CLOCKS_PE_算法性能测试
文章浏览阅读1.2k次。fromhttps://towardsdatascience.com/finding-lane-lines-simple-pipeline-for-lane-detection-d02b62e7572bIdentifying lanes of the road is very common task that human driver performs. This is important ..._lanedetectionlite