用c语言输出回文日期。
时间: 2024-10-29 07:24:48 浏览: 31
在C语言中,输出回文日期通常意味着将年月日按照某种顺序排列后,正读反读都是一样的。由于月份一般不会单独考虑,这里我们可以只关注日期部分的回文检查。以下是一个简单的例子,如何打印出从1001到3112这样的回文日期:
```c
#include <stdio.h>
void print_palindrome_dates(int start_year, int end_year) {
for (int year = start_year; year <= end_year; year++) {
for (int day = 1; day <= 31; day++) {
char date[10]; // 存储年月日,假设两位数表示
sprintf(date, "%04d%02d%02d", year, day, day); // 反向格式化,先输出日
if (strcmp(date, date + 5) == 0) { // 比较字符串的前半部分和后半部分是否相等
printf("%s\n", date);
}
}
}
}
int main() {
print_palindrome_dates(1001, 3112);
return 0;
}
相关问题
用C语言做这个题;题目描述题目 2020年春节期间,有一个特殊的日期引起了大家的注意:2020年2月2日。因为如果将这个日期按 yyyymmdd”的格式写成一个8位数是20200202,恰好是一个回文数。我们称这样的日期是回文日期。 官方 有人表示20200202是“千年一遇”的特殊日子。对此小明很不认同,因为不到2年之后就是下一个回文日 题解 期:20211202即2021年12月2日。 (4019) 也有人表示20200202并不仅仅是一个回文日期,还是一个ABABBABA型的回文日期。对此小明也不认同,因为大约100年后就能遇到下一个ABABBABA型的回文日期:21211212即2121年12月12日。算 记录 不上“千年一遇”,顶多算“千年两遇”。 (1) 给定一个8位数的日期,请你计算该日期之后下一个回文日期和下一个ABABBABA型的回文日期各是哪一天。 输入描述 输入包含一个八位整数N,表示日期。 对干所有评测用例,10000101<N<89991231保证N是一个合法日期的8位数表示。 输出描述 输出两行,每行1个八位数。第一行表示下一个回文日期,第二行表示下一个ABABBABA型的回文日期。
```c
#include <stdio.h>
#include <stdlib.h>
// 判断一个8位数是否是回文数
int is_palindrome(int n) {
int a = n / 10000000; // 第一位
int b = n / 1000000 % 10; // 第二位
int c = n / 100000 % 10; // 第三位
int d = n / 10000 % 10; // 第四位
int e = n / 1000 % 10; // 第五位
int f = n / 100 % 10; // 第六位
int g = n / 10 % 10; // 第七位
int h = n % 10; // 第八位
if (a == h && b == g && c == f && d == e) {
return 1;
}
return 0;
}
// 计算下一个回文日期
int next_palindrome(int n) {
int i = n + 1;
while (!is_palindrome(i)) {
i++;
}
return i;
}
// 判断一个8位数是否是 ABABBABA 型回文数
int is_ababbaba(int n) {
int a = n / 10000000; // 第一位
int b = n / 1000000 % 10; // 第二位
int c = n / 100000 % 10; // 第三位
int d = n / 10000 % 10; // 第四位
int e = n / 1000 % 10; // 第五位
int f = n / 100 % 10; // 第六位
int g = n / 10 % 10; // 第七位
int h = n % 10; // 第八位
if (a == h && b == g && c == f && d == c && e == b && f == a) {
return 1;
}
return 0;
}
// 计算下一个 ABABBABA 型回文日期
int next_ababbaba(int n) {
int i = n + 1;
while (!is_ababbaba(i)) {
i++;
}
return i;
}
int main() {
int n;
scanf("%d", &n);
int next_pal = next_palindrome(n);
int next_ababbaba_pal = next_ababbaba(n);
printf("%d\n%d\n", next_pal, next_ababbaba_pal);
return 0;
}
```
pta5-5 回文日期c语言
好的,我可以帮你解决这个问题。
以下是一种解法:
```c
#include <stdio.h>
int is_leap(int year) { // 判断闰年
return (year % 4 == 0 && year % 100 != 0) || year % 400 == 0;
}
int is_palindrome(int num) { // 判断回文数
int temp = num, reversed = 0;
while (temp > 0) {
reversed = reversed * 10 + temp % 10;
temp /= 10;
}
return reversed == num;
}
int main() {
int year, month, day;
scanf("%d %d %d", &year, &month, &day);
int days_of_month[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; // 各月天数
if (is_leap(year)) { // 闰年 2月天数为 29
days_of_month[2] = 29;
}
int count = 0;
for (int m = 1; m <= 12; m++) { // 枚举月份
if (m == month) { // 跳过当前月份
continue;
}
for (int d = 1; d <= days_of_month[m]; d++) { // 枚举日期
if (d == day) { // 跳过当前日期
continue;
}
int num = year * 10000 + m * 100 + d; // 构造日期数字
if (is_palindrome(num)) { // 判断是否回文日期
printf("%04d-%02d-%02d\n", year, m, d);
count++;
}
}
}
if (count == 0) { // 没有回文日期
printf("INVALID\n");
}
return 0;
}
```
该程序输入一个日期(年、月、日),输出该年中除了该日期之外的所有回文日期。
具体思路是:
1. 定义一个函数 `is_leap` 判断闰年,该函数输入一个年份,返回 1 表示该年为闰年,返回 0 表示该年为平年。
2. 定义一个函数 `is_palindrome` 判断回文数,该函数输入一个整数,返回 1 表示该整数为回文数,返回 0 表示该整数不是回文数。
3. 在 `main` 函数中读入一个日期(年、月、日),并根据该年是否为闰年确定 2 月的天数。
4. 枚举除了该日期之外的所有日期,计算其对应的数字,并调用 `is_palindrome` 函数判断是否为回文数。
5. 如果存在回文日期,则输出该日期;否则输出 `INVALID`。
希望能帮到你!
阅读全文