用C语言写下面这个程序:7-5 大笨钟 分数 300 作者 陈越 单位 浙江大学 微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉。不过由于笨钟自己作息也不是很规律,所以敲钟并不定时。一般敲钟的点数是根据敲钟时间而定的,如果正好在某个整点敲,那么“当”数就等于那个整点数;如果过了整点,就敲下一个整点数。另外,虽然一天有24小时,钟却是只在后半天敲1~12下。例如在23:00敲钟,就是“当当当当当当当当当当当”,而到了23:01就会是“当当当当当当当当当当当当”。在午夜00:00到中午12:00期间(端点时间包括在内),笨钟是不敲的。 下面就请你写个程序,根据当前时间替大笨钟敲钟。 输入格式: 输入第一行按照hh:mm的格式给出当前时间。其中hh是小时,在00到23之间;mm是分钟,在00到59之间。 输出格式: 根据当前时间替大笨钟敲钟,即在一行中输出相应数量个Dang。如果不是敲钟期,则输出: Only hh:mm. Too early to Dang. 其中hh:mm是输入的时间。 输入样例1: 19:05 输出样例1: DangDangDangDangDangDangDangDang 输入样例2: 07:05 输出样例2: Only 07:05. Too early to Dang.
时间: 2024-04-16 17:28:00 浏览: 270
以下是用C语言编写的解决方案:
```c
#include <stdio.h>
#include <stdlib.h>
int main() {
char time[6];
int hours, minutes;
scanf("%s", time);
hours = (time[0] - '0') * 10 + (time[1] - '0');
minutes = (time[3] - '0') * 10 + (time[4] - '0');
if (hours >= 0 && hours < 12) {
printf("Only %s. Too early to Dang.\n", time);
} else {
hours -= 12;
if (minutes > 0) {
hours++;
}
for (int i = 0; i < hours; i++) {
printf("Dang");
}
printf("\n");
}
return 0;
}
```
这个程序首先读取输入的时间,将小时和分钟分别存储在变量`hours`和`minutes`中。然后根据题目要求判断是否可以敲钟,并输出相应的结果。
希望这个程序能够帮助到你!
相关问题
7-5 大笨钟 分数 300 作者 陈越 单位 浙江大学 微博上有个自称“大笨钟V”的家伙,每天敲钟催促码农们爱惜身体早点睡觉。不过由于笨钟自己作息也不是很规律,所以敲钟并不定时。一般敲钟的点数是根据敲钟时间而定的,如果正好在某个整点敲,那么“当”数就等于那个整点数;如果过了整点,就敲下一个整点数。另外,虽然一天有24小时,钟却是只在后半天敲1~12下。例如在23:00敲钟,就是“当当当当当当当当当当当”,而到了23:01就会是“当当当当当当当当当当当当”。在午夜00:00到中午12:00期间(端点时间包括在内),笨钟是不敲的。 下面就请你写个程序,根据当前时间替大笨钟敲钟。 输入格式: 输入第一行按照hh:mm的格式给出当前时间。其中hh是小时,在00到23之间;mm是分钟,在00到59之间。 输出格式: 根据当前时间替大笨钟敲钟,即在一行中输出相应数量个Dang。如果不是敲钟期,则输出: Only hh:mm. Too early to Dang. 其中hh:mm是输入的时间。 输入样例1: 19:05 输出样例1: DangDangDangDangDangDangDangDang 输入样例2: 07:05 输出样例2: Only 07:05. Too early to Dang.
这是一个根据当前时间来敲钟的问题。根据题目描述,我们可以得出以下规律:
1. 如果时间在午夜00:00到中午12:00之间,则输出"Only hh:mm. Too early to Dang."。
2. 如果时间在下午12:00到下午11:59之间,并且分钟数大于等于0,则根据小时数敲钟。
3. 敲钟的规律是从1到12,如果小时数大于12,则减去12。
4. 敲钟的次数等于小时数。
下面是一个Java的实现示例:
```java
import java.util.Scanner;
public class DangClock {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
String time = scanner.nextLine();
scanner.close();
String[] parts = time.split(":");
int hours = Integer.parseInt(parts[0]);
int minutes = Integer.parseInt(parts[1]);
if (hours >= 0 && hours < 12) {
System.out.println("Only " + time + ". Too early to Dang.");
} else {
hours -= 12;
if (minutes > 0) {
hours++;
}
for (int i = 0; i < hours; i++) {
System.out.print("Dang");
}
System.out.println();
}
}
}
```
希望这个示例能够帮助你解决问题!
7-1 考试座位号 分数 10 作者 陈越 单位 浙江大学 每个 pat 考生在参加考试时都会
被分配两个座位号,一个是试机座位,一个是考试座位。正常情况下,考生在入场时先得到试机座位号码,入座进入试机状态后,系统会显示该考生的考试座位号码,考试时考生需要换到考试座位就座。但有些考生迟到了,试机已经结束,他们只能拿着领到的试机座位号码求助于你,从后台查出他们的考试座位号码。
输入格式:
输入第一行给出一个正整数 N(≤1000),随后 N 行,每行给出一个考生的信息:准考证号 试机座位号 考试座位号。其中准考证号由 16 位数字组成,座位从 1 到 N 编号。输入保证每个人的准考证号都不同,且不存在试机座位或考试座位超出范围的情况。
输出格式:
首先输出那些已经通过试机的考生的考试座位号码,随后输出没有通过试机的考生对应试机座位号码。其中后者按照试机座位号递增输出,题目保证递增序列中也是按照输入顺序输出。输出时每个考生的信息占一行,座位号间隔 1 个空格,行末不得有多余空格。
输入样例:
4
10120150912233 2 4
10120150912119 4 1
10120150912126 1 3
10120150912002 3 2
输出样例:
3 1 4 2
10120150912126 1 3
10120150912233 2 4
10120150912002 3 2
10120150912119 4 1
C++ 代码
阅读全文