/*
*时间:2018年4月1日12:39:32-2018年4月1日13:09:15
*题号:1011 A+B和C
*语言:gcc 4.7.2
*分数:15
*题目描述:
给定区间[-231, 231]内的3个整数A、B和C,请判断A+B是否大于C。
输入格式:
输入第1行给出正整数T(<=10),是测试用例的个数。随后给出T组测试用例,每组占一行,顺序给出A、B和C。整数间以空格分隔。
输出格式:
对每组测试用例,在一行中输出“Case #X: true”如果A+B>C,否则输出“Case #X: false”,其中X是测试用例的编号(从1开始)。
输入样例:
4
1 2 3
2 3 4
2147483647 0 2147483646
0 -2147483648 -2147483647
输出样例:
Case #1: false
Case #2: true
Case #3: true
Case #4: false
*/
#include <stdio.h>
int main()
{
int T;
scanf("%d", &T);
long a[T-1]; //题目给的范围是[-2^31-2^31]所以不能用int类型
long b[T-1];
long c[T-1];
long i;
for (i=0; i<=T-1; i++)
{
scanf("%ld", &a[i]);
scanf("%ld", &b[i]);
scanf("%ld", &c[i]);
}
for (i=0; i<=T-1; i++)
{
if (a[i] + b[i] > c[i])
printf("Case #%d: true", i+1); //注意输出的次数比数组下标大1
else
printf("Case #%d: false", i+1);
printf("\n");
}
return 0;
}
/*
*时间:2018年4月1日14:49:37-2018年4月1日15:15:00
*题号:1016. 部分A+B
*语言:gcc 4.7.2
*分数:15
*题目描述:
正整数A的“DA(为1位整数)部分”定义为由A中所有DA组成的新整数PA。例如:给定A = 3862767,DA = 6,
则A的“6部分”PA是66,因为A中有2个6。现给定A、DA、B、DB,请编写程序计算PA + PB。
输入格式:
输入在一行中依次给出A、DA、B、DB,中间以空格分隔,其中0 < A, B < 10^10。
输出格式:
在一行中输出PA + PB的值。
输入样例1:
3862767 6 13530293 3
输出样例1:
399
输入样例2:
3862767 1 13530293 8
输出样例2:
0
*/
#include <stdio.h>
int main()
{
long A;
long B;
int DA, DB;
int PA = 0;
int PB = 0;
scanf("%ld", A);
scanf("%d", DA);
scanf("%ld", B);
scanf("%d", DB);
int i, temp;
while (A != 0) //检查A的每一位,每有一位与DA相同则右边加一个DA
{
temp = A % 10;
if (DA == temp)
PA = PA * 10 + DA;
A /= 10;
}
while (B != 0)
{
temp = B % 10;
if (DB == temp)
PB = PB * 10 + DB;
B /= 10;
}
printf("%d",PA + PB);
return 0;
}
/*
*时间:2018年4月1日15:17:08-2018年4月1日15:49:39
*题号:1026. 程序运行时间
*语言:gcc 4.7.2
*分数:15
*题目描述:
要获得一个C语言程序的运行时间,常用的方法是调用头文件time.h,其中提供了clock()函数,可以捕捉从程序开
始运行到clock()被调用时所耗费的时间。这个时间单位是clock tick,即“时钟打点”。同时还有一个常数CLK_TCK
,给出了机器时钟每秒所走的时钟打点数。于是为了获得一个函数f的运行时间,我们只要在调用f之前先调用
clock(),获得一个时钟打点数C1;在f执行完成后再调用clock(),获得另一个时钟打点数C2;两次获得的时钟打
点数之差(C2-C1)就是f运行所消耗的时钟打点数,再除以常数CLK_TCK,就得到了以秒为单位的运行时间。
这里不妨简单假设常数CLK_TCK为100。现给定被测函数前后两次获得的时钟打点数,请你给出被测函数运行的时间。
输入格式:
输入在一行中顺序给出2个整数C1和C2。注意两次获得的时钟打点数肯定不相同,即C1 < C2,并且取值在[0, 10^7]。
输出格式:
在一行中输出被测函数运行的时间。运行时间必须按照“hh:mm:ss”(即2位的“时:分:秒”)格式输出;
不足1秒的时间四舍五入到秒。
输入样例:
123 4577973
输出样例:
12:42:59
*/
#include<stdio.h>
int main(void)
{
int C1, C2;
scanf("%d", &C1);
scanf("%d", &C2);
int times = (C2 - C1);
times = times / 100;
if ((C2 - C1)%100 >= 50)
times++;
int hh, mm, ss;
hh = times / (60*60);
mm = (times % (60*60)) / 60;
ss = (times % (60*60)) % 60;
printf("%02d:%02d:%02d",hh, mm, ss); //注意输出格式%02d表示长度为两格,不满两格前面填0
return 0;
}
/*
*时间:2018年4月1日15:51:08
*题号:1046. 划拳
*语言:gcc 4.7.2
*分数:15
*题目描述:
划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划
出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就赢了,输家罚一杯酒。两人同赢或两人同输
则继续下一轮,直到唯一的赢家出现。
下面给出甲、乙两人的划拳记录,请你统计他们最后分别喝了多少杯酒。
输入格式:
输入第一行先给出一个正整数N(<=100),随后N行,每行给出一轮划拳的记录,格式为:
甲喊 甲划 乙喊 乙划
其中“喊”是喊出的数字,“划”是划出的数字,均为不超过100的正整数(两只手一起划)。
输出格式:
在一行中先后输出甲、乙两人喝酒的杯数,其间以一个空格分隔。
输入样例:
5
8 10 9 12
5 10 5 10
3 8 5 12
12 18 1 13
4 16 12 15
输出样例:
1 2
*/
#include <stdio.h>
int main()
{
int T;
scanf("%d", &T);
if ( T == 0)
printf("0 0");
int num_J = 0;
int num_Y = 0;
int J_HAN[T-1];
int J_HUA[T-1];
int Y_HAN[T-1];
int Y_HUA[T-1];
int i;
for (i=0; i<T; i++)
{
scanf("%d", &J_HAN[i]);
scanf("%d", &J_HUA[i]);
scanf("%d", &Y_HAN[i]);
scanf("%d", &Y_HUA[i]);
}
for (i=0; i<T; i++)
{
if(J_HUA[i] == Y_HUA[i])
{
continue;
}
else if (J_HAN[i] + Y_HAN[i] == J_HUA[i])
{
num_Y++;
}
else if (J_HAN[i] + Y_HAN[i] == Y_HUA[i])
{
num_J++;
}
}
printf("%d %d",num_J, num_Y);
return 0;
}
/*
*之前continue那里把划和喊搞反了,一直只有14分,现在已经根正
*/
【PAT】1011/1016/1026/1046
最新推荐文章于 2022-01-27 08:35:28 发布