【C语言】[NOIP1999]回文数

文章目录


题目

[NOIP1999]回文数 链接: link

思路

因为至多可能会进行30次加法,所以最终的数字长度很有可能会超过int类型的最大范围,导致溢出,所以我们采用数组的方式记录数字。

c 复制代码
int n;
scanf("%d", &n);//读取进制
char m[200] = { 0 };//因为之多会进行30次循环,所以,最后数字的大小可能会很大,所以我们可以通过创建一个足够长的数组来存储
scanf("%s", &m);//读取回文数

这道题中判断是否进行下一次加法的一句就是当前数是否为回文数,所以我们先自定义一个可以判断是否为回文数的函数 is_huiwen(char* m) ,并且通过输出来判断是否为回文数

c 复制代码
int is_huiwen(char* m)//判断是否为回文数,是返回1,否返回0
{
	for (int i = 0; i < strlen(m); i++)
	{
		if (m[i] != m[strlen(m) - 1 - i])
			return 0;
	}
	return 1;
}

自定义 sum 函数,进行回文数相加操作

但是这个过程中有很多点需要注意

  1. 传进去是字符串的形式,我们可以利用自定义函数 ctio 转换为整形后进行加法,最后再用自定义函数 itoc 转换为字符输出
  2. 加法后的数字位数很有可能与之前不同,所以我们可以创建一个新的数组来储存加法后的数字,最后倒回去。
  3. 加法过程中存在仅为,需要提前设置 jw 来辅助
c 复制代码
int ctoi(char x)//字符转int
{
	int y = 0;
	if (x >= 'A' && x <= 'E')
	{
		y = x - 'A' + 10;
	}
	if (x >= '0' && x <= '9')
	{
		y = x - '0';
	}
	return y;
}
char itoc(int x)//int转字符
{
	char y;
	if (x < 10) y = x + '0';
	else y = x - 10 + 'A';
	return y;
}

void sum(char* m,int n)//计算x进制加法,把结果覆盖到m数组中
{
	char sum[200] = { 0 };//sum记录顺序最左边为个位.
	int len = strlen(m), i, jw = 0;//使用jw来记录进位情况
	for (i = 0; i < len; i++)
	{
		int x, y;
		x = ctoi(m[i]);
		y = ctoi(m[len - i - 1]);
		int s = x + y;
		sum[i] = itoc((s + jw) % n);
		jw = (s + jw) / n;
	}
	if (jw != 0) sum[i] = itoc(jw);//最后一位进位
	len = strlen(sum);
	for (i = 0; i < len; i++)//覆盖m
	{
		m[i] = sum[len - i - 1];
	}
}

代码呈现

c 复制代码
#include<stdio.h>
#include<assert.h>
#include<string.h>





int ctoi(char x) { //字符转int
    int y = 0;
    if (x >= 'A' && x <= 'E') {
        y = x - 'A' + 10;
    }
    if (x >= '0' && x <= '9') {
        y = x - '0';
    }
    return y;
}
char itoc(int x) { //int转字符
    char y;
    if (x < 10) y = x + '0';
    else y = x - 10 + 'A';
    return y;
}


void sum(char* m, int n) { //计算x进制加法,把结果覆盖到m数组中
    char sum[200] = { 0 };//sum记录顺序最左边为个位.
    int len = strlen(m), i, jw = 0;//使用jw来记录进位情况
    for (i = 0; i < len; i++) {
        int x, y;
        x = ctoi(m[i]);
        y = ctoi(m[len - i - 1]);
        int s = x + y;
        sum[i] = itoc((s + jw) % n);
        jw = (s + jw) / n;
    }
    if (jw != 0) sum[i] = itoc(jw);//最后一位进位
    len = strlen(sum);
    for (i = 0; i < len; i++) { //覆盖m
        m[i] = sum[len - i - 1];
    }
}


int is_huiwen(char* m) { //判断是否为回文数,是返回1,否返回0
    for (int i = 0; i < strlen(m); i++) {
        if (m[i] != m[strlen(m) - 1 - i])
            return 0;
    }
    return 1;
}

int main() {
    int n;
    scanf("%d", &n);//读取进制
    char m[200] = { 0 };//因为之多会进行30次循环,所以,最后数字的大小可能会很大,所以我们可以通过创建一个足够长的数组来存储
    scanf("%s", &m);//读取回文数

    int count = 0;
    while (count < 31) {
        if (is_huiwen(
                    m)) { //判断当前是否为回文数,如果是回文数,就直接退出
            break;
        } else {
            sum(m, n);
            count++;
        }
    }
    if (count == 31)
        printf("Impossible!");
    else
        printf("STEP=%d", count);

    return 0;
}
相关推荐
pianmian17 分钟前
python数据结构基础(7)
数据结构·算法
闲晨9 分钟前
C++ 继承:代码传承的魔法棒,开启奇幻编程之旅
java·c语言·开发语言·c++·经验分享
好奇龙猫2 小时前
【学习AI-相关路程-mnist手写数字分类-win-硬件:windows-自我学习AI-实验步骤-全连接神经网络(BPnetwork)-操作流程(3) 】
人工智能·算法
sp_fyf_20243 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-11-01
人工智能·深度学习·神经网络·算法·机器学习·语言模型·数据挖掘
香菜大丸3 小时前
链表的归并排序
数据结构·算法·链表
jrrz08283 小时前
LeetCode 热题100(七)【链表】(1)
数据结构·c++·算法·leetcode·链表
oliveira-time3 小时前
golang学习2
算法
南宫生4 小时前
贪心算法习题其四【力扣】【算法学习day.21】
学习·算法·leetcode·链表·贪心算法
懒惰才能让科技进步5 小时前
从零学习大模型(十二)-----基于梯度的重要性剪枝(Gradient-based Pruning)
人工智能·深度学习·学习·算法·chatgpt·transformer·剪枝
DARLING Zero two♡5 小时前
关于我、重生到500年前凭借C语言改变世界科技vlog.16——万字详解指针概念及技巧
c语言·开发语言·科技