循环结构-回文数

编写程序计算车速:

一个人开车去旅行,某时刻发现里程表上显示98589.经过两个小时,第一次显示了下一个回文数。求里程以及速度。

回文数:一个数的数字排列正反相同,例如98589,13431

int main()
{
    int s1 = 98589;
    int s2 = s1;
    int a, b, c;
    while (true)
    {
        s2++;
        //假设此数为10000a+1000b+100c+10b+a
        a = s2 / 10000;
        b = (s2 - a * 10000) / 1000;
        c = (s2 - a * 10000 - b * 1000) / 100;
        if (s2 == (10000 * a + 1000 * b + 100 * c + 10 * b + a))
        {
            break;//跳出while循环
        }
    }
    printf("第二次里程为%d\n", s2);
    printf("速度为%dkm/h\n", (s2 - s1) / 2);
    return 0;
}

当然,循环代码可以有其他写法。

时间: 2024-10-09 15:40:00

循环结构-回文数的相关文章

Java蓝桥杯--基础练习 (6)回文数

关键词: 循环 判断 回文数 题目: 解决方法: 1 package com.algorithm.java.blueBirdge; 2 3 //import java.util.Scanner; 4 5 public class Palindrome { 6 public static void main(String[] args){ 7 8 for(int i=1000;i<=9999;i++){ 9 if(i%10==i/1000 && ( ((i%100)/10)==((i/

要求循环输入一个数,判断是否为回文数

import java.util.Scanner; public class HuiWenShu { public static void main(String[] args) { Scanner input = new Scanner(System.in); char c = 'y'; //初始化c为y,为下面的循环做好准备 while(c == 'y'){ while(c == 'y'){ System.out.println("请随意输入一个大于三位的奇位数"); //回文数属

LeetCode 9 Palindrome Number (回文数)

翻译 确定一个整数是否是回文数.不能使用额外的空间. 一些提示: 负数能不能是回文数呢?(比如,-1) 如果你想将整数转换成字符串,但要注意限制使用额外的空间. 你也可以考虑翻转一个整数. 然而,如果你已经解决了问题"翻转整数(译者注:LeetCode 第七题), 那么你应该知道翻转的整数可能会造成溢出. 你将如何处理这种情况? 这是一个解决该问题更通用的方法. 原文 Determine whether an integer is a palindrome. Do this without ex

习题-四季-回文数-不死神兔

1-键盘录入月份,输出对应的季节.一年有四季;3,4,5春季;6,7,8夏季;9,10,11秋季;12,1,2冬季 public class Demo02Test {     public static void main(String[] args) {         // 键盘录入一个月份,用Scanner实现         Scanner sc = new Scanner(System.in);         // 接收数据         System.out.println("请

输出1-256之间一个数的平方是回文数

方法: 通过一个函数求出这个数一共是几位数 循环取余数依次放入临时数组 通过数组下标循环判断 1 //功能:打印所有不超过 n( n<256)的其平方具有对称性的数(也称回文数) 2 3 4 5 #include<stdio.h> 6 #include<stdlib.h> 7 8 int judg(int); 9 int getBit(int); //返回整数值的位数 10 11 void main(){ 12 for (int i = 0; i < 256; i++)

算法训练 回文数

问题描述 若一个数(首位不为零)从左向右读与从右向左读都一样,我们就将其称之为回文数. 例如:给定一个10进制数56,将56加65(即把56从右向左读),得到121是一个回文数. 又如:对于10进制数87: STEP1:87+78 = 165 STEP2:165+561 = 726 STEP3:726+627 = 1353 STEP4:1353+3531 = 4884 在这里的一步是指进行了一次N进制的加法,上例最少用了4步得到回文数4884. 写一个程序,给定一个N(2<=N<=10或N=1

48.输入任意正整数,编程判断该数是否为回文数(回文数是指从左到右读与从右到左读一样,如12321)

//1.输入一个数,将其每一位分离,并保存如一个数组 //2.判断数组最后录入的一位是第几位 //3.循环判断是否满足回问数的要求 #include<iostream> using namespace std; int main() { int n,temp; int k=0; int a[20]; cout<<"please input an number: "<<endl; cin>>n; for(int i=0;i<20;i+

表示回文数,将数字倒过来

比如你输入的数是12321:循环开始前:m=12321,sum=0:第1次循环结束:m=1232,sum=1:第2次循环结束:m=123,sum = 12:第3次循环结束:m=12,sum=123:第4次循环结束:m=1,sum=1232:第5次循环结束:m=0,sum=12321.输入的是几位数就循环几次.判断的思路就是,通过循环依次把m的个位,十位,百位...上的数取出来,与sum*10相加.这样得到的数sum就是m颠倒之后的数,如果两者相等,那就是回文数. 1 sum = 0; 2 for

回文数的实现代码

回文数,顾名思义,就是一种数,正序逆向读取完全一致.像12321,4567654就是回文数. 用C语言实现回文数的判断呢,很简单.在这呢,我做简单的介绍. 首先,用判断语句实现.判断语句呢,就是通过循环和简单的运算符,找出该数的逆向读取的数据,于本身进行比较便得到了. 代码如下: #include<stdio.h> void main() { int num; scanf("%d",&num); int min = 0, max = num; while (max