首页 > 其他分享 >12.13

12.13

时间:2024-12-14 20:02:13浏览次数:5  
标签:10 int scanf ++ 12.13 printf include

在对银行账户等重要权限设置密码的时候,我们常常遇到这样的烦恼:如果为了好记用生日吧,容易被破解,不安全;如果设置不好记的密码,又担心自己也会忘记;如果写在纸上,担心纸张被别人发现或弄丢了...

    这个程序的任务就是把一串拼音字母转换为6位数字(密码)。我们可以使用任何好记的拼音串(比如名字,王喜明,就写:wangximing)作为输入,程序输出6位数字。

    变换的过程如下:

    第一步. 把字符串6个一组折叠起来,比如wangximing则变为:
    wangxi
    ming

    第二步. 把所有垂直在同一个位置的字符的ascii码值相加,得出6个数字,如上面的例子,则得出:
    228 202 220 206 120 105

    第三步. 再把每个数字“缩位”处理:就是把每个位的数字相加,得出的数字如果不是一位数字,就再缩位,直到变成一位数字为止。例如: 228 => 2+2+8=12 => 1+2=3

    上面的数字缩位后变为:344836, 这就是程序最终的输出结果!

    要求程序从标准输入接收数据,在标准输出上输出结果。

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

int shrinkValue(int sum) 
{
    int temp = sum;
    while (temp >= 10) 
    {
        int newSum = 0;
        while (temp > 0) 
        {
            newSum += temp % 10;
            temp /= 10;
        }
        temp = newSum;
    }
    return temp;
}

int main()
{
    int n;
    scanf("%d", &n);

    char strings[n][100];

    for (int i = 0; i < n; i++) 
    {
        scanf("%s", strings[i]);
    }

    for (int i = 0; i < n; i++)
    {
        int length = strlen(strings[i]);
        int foldedLength = length / 6;
        if (length % 6 != 0) 
        {
            foldedLength++;
        }

        int sums[6] = { 0 };

        for (int j = 0; j < foldedLength; j++) 
        {
            for (int k = 0; k < 6 && j * 6 + k < length; k++) 
            {
                sums[k] += strings[i][j * 6 + k];
            }
        }

        for (int j = 0; j < 6; j++) 
        {
            int shrunkValue = shrinkValue(sums[j]);
            printf("%d", shrunkValue);
        }
        printf("\n");
    }

    return 0;
}

众所周知,实验室的小叶子长的很黑,但是,他自己却总是喜欢颠倒黑白,总喜欢把黑的说成白的(比如 他自己,O(∩_∩)O哈哈~)。这不,有一天,他又开始了他的颠倒之路了。他拿出了两个数,试图颠倒这两个数。规则如下:如果这两个数的反转的和等于两个数和的反转,例如: 12和34。12的反转是21,34的反转是43,21+43=64,而12+34=46,46的反转为64。两个经过反转的数相等,那么他就颠倒失败了,否则他就成功了!!

#include<stdio.h>
int fz(int a)
{
	int nx = 0;
	while (a > 0)
	{
		nx = nx * 10 + a % 10;
		a /= 10;
	}
	return nx;
}
int main()
{
	int n;
	scanf("%d", &n);
	while (n--)
	{
		int a, b;
		scanf("%d %d", &a, &b);
		if (fz(a) + fz(b) == fz(a + b))
			printf("%d\n", a + b);
		else
			printf("小叶子颠倒成功\n");
	}
	return 0;
}

 设有一数列,包含10个数,已按升序排好。现要求编一程序,它能够把从指定位置m开始的n个数按逆序重新排列并输出新的完整数列。

#include<stdio.h>
int main()
{
	int m, n;
	int arr[10];
	char arr1[3], arr2[3];
	for (int i = 0; i < 10; i++)
	{
		scanf("%d", &arr[i]);
	}
	getchar();
	scanf("m:%d", &m);
	getchar();
	scanf("n:%d", &n);
	for (int i = 0; i < m; i++)
	{
		printf("%d ", arr[i]);
	}
	for (int j = m + n-1; j >= m; j--)
	{
		printf("%d ", arr[j]);
	}
	for (int k = m + n; k < 10; k++)
	{
		printf("%d ", arr[k]); 
	}
	return 0;
}

 最近眺爷无聊的玩起了数格点的游戏,现给定平面上的两个格点 p1 = (x1,y1) 和 p2 = (x2,y2), 他想找出线段p1p2上除p1和p2以外一共有几个格点?但他总是数错, 你能写个程序帮帮他吗?

#include<stdio.h>
#include<math.h>
int main()
{
	int x1, y1; int x2, y2;
	scanf("%d %d", &x1, &y1);
	scanf("%d %d", &x2, &y2);
	int a = abs(x1 - x2);
	int b = abs(y1 - y2);
	int count = 0;
	for (int i = 1; i < a + b; i++)
	{
		if (a % i == 0 && b % i == 0)
			count++;
	}
	printf("%d", count);
	return 0;
}

标签:10,int,scanf,++,12.13,printf,include
From: https://blog.csdn.net/2401_89524595/article/details/144461002

相关文章

  • 2024.12.13 周五
    2024.12.13周五Q1.1000Polycarphasaproblem—hislaptopkeyboardisbroken.Now,whenhepressesthe'b'key,itactslikeanunusualbackspace:itdeletesthelast(rightmost)lowercaseletterinthetypedstring.Iftherearenolowercase......
  • Connection to tcp://192.168.112.137:1935?tcp_nodelay=0 failed: Connection timed
    记录一下自己的报错和解决步骤输入catnginx.conf 查看Nginx的配置文件nginx.conf修改nginx核心配置文件nginx,添加rtmp模块rtmp{                                          ......
  • 启发式评估(Heuristic Evaluation)--转载 [2011.12.13 sina blog]
    启发式评估(HeuristicEvaluation) -[一架好书--读书学习的收获]2008年08月07日分类: 一架好书--读书学习的收获  版权声明:转载时请以超链接形式标明文章原始出处和作者信息及本声明http://buyantang.blogbus.com/logs/27286224.htmlUsabilityInspectionMethods,Edit......
  • P6864 [RC-03] 记忆 题解(评分:8.1)(2023.12.13)
    前言这下又不是官解了吧?模拟赛题,在一个月后又出现在了数据结构讲稿上,令人忍俊不禁。Solution官方解法是用线段树加矩阵,不过赛时的我显然没这么聪明,是想不到的。赛时我就只知道先发掘一些答案的性质。一、一些性质首先,发现这个撤销操作比较棘手,考虑没有撤销操作的情况下,每一......
  • 12.13
    《程序员修炼之道》第七章在项目开始之前的阅读笔记这一章讨论了在项目开始之前要面临的一些问题和挑战,以及如何应对和解决它们。作者提出了以下几个主题:不要搜集需求,而要挖掘需求。需求是用户想要解决的问题,而不是用户目前做事情的方式。要站在用户的角度,了解他们的真正需求和......
  • 12.13
    UserMapperpackagecom.example.mapper;importcom.example.pojo.Agent;importcom.example.pojo.Customer;importcom.example.pojo.House;importcom.example.pojo.Users;importorg.apache.ibatis.annotations.*;importjava.util.List;@Mapperpublicinterf......
  • 12.13
    UserMapperpackagecom.example.mapper;importcom.example.pojo.Agent;importcom.example.pojo.Customer;importcom.example.pojo.House;importcom.example.pojo.Users;importorg.apache.ibatis.annotations.*;importjava.util.List;@Mapperpublicinterfa......
  • 12.13日
    早上五点多一点就醒来了,在床上坐着,闭目,再睁眼就是六点了。舍友们都还在睡梦,我静静穿好衣服,拿好洗漱用品,洗漱完简单收拾了一下,拿上早上上课用的书笔就离开了。一晚上的翻来覆去,身体虚弱,六点半的食堂也没什么吃的,我就只吃了两根油条,喝了一杯奶。今天的雪更大了,吃完早餐下台阶的时候......
  • 12.13每日总结
    packagetuxiang;importokhttp3.*;importorg.json.JSONObject;importjavax.imageio.ImageIO;importjavax.swing.*;importjava.awt.*;importjava.awt.event.ActionEvent;importjava.awt.event.ActionListener;importjava.awt.image.BufferedImage;importja......
  • 12.13 闲话
    昨天\(12.12\)今年是西安事变\(87\)周年所以\(\mathrm{CCF}\)送给\(\mathrm{HE}\)省队一个\(\mathrm{HE}\)事变,现在看起来大家都已经快似了(悲)今天打了个Hash水题???企鹅DescriptionPenguinQQ是中国最大、最具影响力的SNS(SocialNetworkingServices)网站,以实名制为基础,为用户......