CSU21级期末

问题 C: 21级期末机试-密码设置(20分)
[命题人 : 外部导入]
时间限制 : 1.000 sec 内存限制 : 128 MB

题目描述
小南有个密码本,详细记录着她在每个网站上的密码,但是有的密码设置可能存在安全问题,她想请聪明的你帮她看看密码设置是否正确。安全密码的判断有以下几个规则:
(1)密码长度必须≥8
(2)包含数字
(3)包含大写字母
(4)包含小写字母
(5)至少包含6个特殊字符(! @ # $ * ~)中的一个
以上规则,除(1)必须满足外,其他四个条件至少满足其中三个才是安全的密码。
输入
多组样例。每行一个样例,输入一个字符串S代表密码,字符串S的长度len(S)满足:1≤len(S)≤30,且只包含密码设置要求的数字、字母和特殊字符,无其他非法字符。
输出
对于每一组样例,输出一个判断结果。如果满足安全密码的设置要求则输出yes,不满足则输出no。每个输出占一行。
样例输入 Copy
ttttttttt
123Aa~
123456QqWe
aQwe!1234
123$#abc
样例输出 Copy
no
no
yes
yes
yes

#include<stdio.h>
#include<string.h>
int main(void)
{char arr[31] = { 0 };while (~scanf("%s", &arr)){int sum = 0;int flag1 = 0, flag2 = 0, flag3 = 0, flag4 = 0;int n = strlen(arr);if (n >= 8){for (int i = 0; i < n; i++){if (arr[i] >= '1' && arr[i] <= '9')flag1 = 1;else if (arr[i] >= 'A' && arr[i] <= 'Z')flag2 = 1;else if (arr[i] >= 'a' && arr[i] <= 'z')flag3 = 1;else if (arr[i] == '!' || arr[i] == '@' || arr[i] == '#' || arr[i] == '$' || arr[i] == '*' || arr[i] == '~')flag4 = 1;}if (flag1 == 1)sum++;if (flag2 == 1)sum++;if (flag3 == 1)sum++;if (flag4 == 1)sum++;if (sum >= 3){printf("yes\n");}else{printf("no\n");}}else{printf("no\n");}}return 0;
}

问题 D: 21级期末机试-实数相加(10分)
[命题人 : 外部导入]
时间限制 : 1.000 sec 内存限制 : 128 MB

题目描述
C语言就要期末考试了,经过一学期的学习,小南学会了分数相加、分数相减、大整数相加,可就是没有尝试过将两个最大达400位的实数相加。在调试过程中,小南遇到了很多问题,一直解决不了。你能帮他编写一个程序实现两个实数相加吗?
输入
多组样例。每行输入一个样例包括两个用空格分开的实数x和y,其中x和y是长度不大于400位的非负实数。注意,非负实数中也可能包括非负整数,正整数会省略小数点和后面的0,只包括整数部分。
输出
对于每一行输入,输出两个实数x和y相加的结果。输出结果中整数部分的前面和小数部分的末尾不输出多余的0;如果是整数,不输出小数点和小数点后面的0。每个输出占一行。
样例输入 Copy
1.1 2.9
1.1111111111 2.3444323343
1 1.1
1.1111 1.1889
样例输出 Copy
4
3.4555434454
2.1
2.3

#include<stdio.h>
#include<string.h>
#define count(xLength,xzheng,x,xxiao) \for (int i = 0; i < xLength; i++)\
{\if (x[i] != '.')\xzheng++;\else\{\xxiao = xLength - xzheng - 1;break;\}\}
#define MAX(x,y) x>y?x:yvoid fuxiaoshu(char* x, int xzheng, char* xnew, int xxiao)
{while (*xnew != 0) xnew++;for (int i = xzheng +1;i < xzheng + 1 + xxiao; i++){*xnew = x[i];xnew++;}
}
int main(void)
{char x[410] = { 0 };char y[410] = { 0 };while (~scanf("%s %s", x, y)){int xLength = strlen(x), xzheng = 0, xxiao = 0;int yLength = strlen(y), yzheng = 0, yxiao = 0;count(xLength, xzheng, x, xxiao);count(yLength, yzheng, y, yxiao);int mzheng = MAX(xLength, yLength);char xnew[900] = { 0 }, ynew[900] = { 0 };if (xzheng >= yzheng){strncpy(xnew, x,xzheng);for (int i = 0; i < xzheng - yzheng; i++){ynew[i] = '0';}strcat(ynew, y);for (int i = xzheng; i < yLength+xzheng; i++){ynew[i] = 0;}}else{strncpy(ynew, y,yzheng);for (int i = 0; i < yzheng - xzheng; i++){xnew[i] = '0';}strcat(xnew, x);for (int i = yzheng; i <yLength+yzheng; i++){xnew[i] = 0;}}mzheng = (MAX(xzheng, yzheng)) + (MAX(xxiao, yxiao))+1;fuxiaoshu(x, xzheng, xnew, xxiao);fuxiaoshu(y, yzheng, ynew, yxiao);char arr[900] = { 0 };for (int i = mzheng-2; i>=1;i--){if (xnew[i] == 0)xnew[i] = '0';if (ynew[i] ==0 )ynew[i] = '0';arr[i] += xnew[i] - '0' + ynew[i] - '0'+'0';if (arr[i] -'0' >= 10){arr[i] -= 10;arr[i - 1]++;}}arr[0] += xnew[0] - '0' + ynew[0] - '0';printf("%d", arr[0]);arr[0] += '0';for (int i = 1; i < (MAX(xzheng, yzheng)); i++){printf("%c", arr[i]);}int nn = strlen(arr)-1;while (arr[nn] == '0'&&nn>= (MAX(xzheng, yzheng))){arr[nn] = 0;nn--;}if (nn+1 > (MAX(xzheng, yzheng))){printf(".%s\n", arr + (MAX(xzheng, yzheng)));}else{printf("\n");}}return 0;
}

我的思路是把整数和小数的小数点去掉,当作一个大的字符串相加。给少的前面补齐0,后面补齐0.
还有一种思路是分开算,将整数和小数。
犯的错误:数组开的小了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/219524.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java笔记草稿——已完成

导航&#xff1a; 【Java笔记踩坑汇总】Java基础JavaWebSSMSpringBootSpringCloud瑞吉外卖/黑马旅游/谷粒商城/学成在线设计模式面试题汇总性能调优/架构设计源码-CSDN博客 推荐学习视频&#xff1a; 黑马程序员全套Java教程_哔哩哔哩 尚硅谷Java入门视频教程_哔哩哔哩 目录 零…

[BUUCTF 2018]Online Tool1

提示 利用nmap上传文件 首先进行代码分析&#xff1a; 首先是进行判断http信息头里是否在HTTP_X_FORWARDED_FOR并且是否有参数 $_SERVER[“HTTP_X_FORWARDED_FOR”] 的值才是客户端真正的IP&#xff08;如果是多层代理&#xff0c;该值可能是由客户端真正IP和多个代理服务…

C++(11):forward_as_tuple通过右值构建tuple

tuple在构造时,会通过拷贝构造或移动构造对对象进行复制或移动: #include <iostream> #include <tuple> using namespace std;class A{ public:A(int i): m_i(i){cout<<"construct A, "<<"m_i="<<m_i<<", add…

基于Spring,MyBatis,SpringMVC的农业信息智能化种植系统

文章目录 项目介绍主要功能截图:部分代码展示设计总结项目获取方式🍅 作者主页:超级无敌暴龙战士塔塔开 🍅 简介:Java领域优质创作者🏆、 简历模板、学习资料、面试题库【关注我,都给你】 🍅文末获取源码联系🍅 项目介绍 基于SSM的农业信息智能化种植系统,java项…

二十五、图形视图框架

二十五、图形视图框架 我们将要用到三个类&#xff0c;QGraphicsView&#xff08;视图类&#xff09;、QGraphicsScene&#xff08;场景类&#xff09;、QGraphicsItem&#xff08;图元类&#xff09;。 QGraphicsView&#xff08;视图类&#xff09; 继承QWidget类&#xf…

玩转Docker(一):容器生态系统

文章目录 一、核心技术二、平台技术三、支持技术 本文结构如下&#xff1a; 一、核心技术 容器核心技术是指能够让Container在host上运行起来的那些技术。 &#xff08;1&#xff09;容器规范 容器不光是Docker&#xff0c;还有其他容器&#xff0c;比如CoreOS的rkt。为了保证…

IO / 标准IO 和 文件IO 的总结

我将标准IO和文件IO有关概念、api总结在一张表格了&#xff0c;方便查找使用 标准IO 文件IO 概念 使用库函数实现&#xff0c;将内核提供的IO函数接口进行了再次封装&#xff0c;因为有缓冲区&#xff0c;所以效率比文件IO高 对文件进行操作&#xff0c;使用的是文件指针来…

网络推理之深度学习推理框架

如何选择深度学习推理框架&#xff1f; PyTorch vs LibTorch&#xff1a;网络推理速度谁更快&#xff1f; 高质量C进阶[2]&#xff1a;如何让线性代数加速1000倍&#xff1f; TensorRT: ONNX:

微服务--07--Sentienl中使用的限流算法

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 Sentienl中使用的限流算法1、计数器固定窗口算法2、计数器滑动窗口算法----&#xff08;默认&#xff09;3、漏桶算法----&#xff08;排队等待&#xff09;4、令牌…

node.js 启一个前端代理服务,代码直接改一改拿来用

文章目录 前言一、分析技术二、操作步骤2.1、下载依赖2.2、创建一个 serve.js 文件2.3、js 文件中写入以下代码 三、运行&#xff1a; node serve四、结果展示五、总结六、感谢 前言 有时候我们需要做一些基础的页面时&#xff0c;在研发过程中需要代理调用接口避免浏览器跨域…

AI全栈大模型工程师(二十六)如何选择 GPU 和云服务厂商

&#x1f4a1; 这节课会带给你 如何选择 GPU 和云服务厂商&#xff0c;追求最高性价比 如何部署自己 fine-tune 的模型&#xff0c;向业务提供高可用推理服务 如何控制内容安全&#xff0c;做好算法备案&#xff0c;确保合规 开始上课&#xff01; 硬件选型 当我们为模型训练及…

电子学会C/C++编程等级考试2022年12月(五级)真题解析

C/C++等级考试(1~8级)全部真题・点这里 第1题:漫漫回国路 2020年5月,国际航班机票难求。一位在美国华盛顿的中国留学生,因为一些原因必须在本周内回到北京。现在已知各个机场之间的航班情况,求问他回不回得来(不考虑转机次数和机票价格)。 时间限制:1000 内存限制:655…

golang 基于数组、切片、链表实现队列

数组 package mainimport ("errors""fmt" )func main() {// 创建一个简单队列// 如果head tail 队列空// 如果tail len(array) - 1// 整体做迁移 如果head 0 队列满stack1 : createQueue[int]()err : stack1.push(1)// 处理错误 后面的就不处理了if er…

Ajax原理以及优缺点

Ajax原理 1.Ajax的原理简单来说是在用户和服务器之间加了—个中间层(AJAX引擎)&#xff0c;通过XmlHttpRequest对象来向服务器发异步请求&#xff0c; 2.从服务器获得数据&#xff0c;然后用javascript来操作DOM而更新页面。使用户操作与服务器响应异步化。 3.这其中最关键的一…

Java----冒泡排序、选择排序、插入排序、快速排序、堆排序

int[] arr {4, 2, 7, 1, 5, 9, 3, 6, 8}; 冒泡排序 for(int i 0; i < arr.length-1; i) //外循环是控制排序的次数n-1, 每次循环结束确定一个最大值{for(int j 0; j < arr.length - 1 - i; j) // 内循环是第i次循环中比较的次数n-i{if(arr[j] > arr[j1]){//前面一…

LeetCode-23. 合并 K 个升序链表

问题分析 先建立一个小顶堆将每一路的最小元素都加入小顶堆&#xff0c;此时堆顶元素就是全局的最小值将堆顶元素弹出。若堆顶元素所在的数组不为空&#xff0c;则将下一元素加入堆中重复2、3操作&#xff0c;直到所有数据都读取完毕将堆内元素按顺序读出&#xff0c;并清空堆…

双系统安装显卡驱动

安装步骤 更新系统: 在安装任何新软件之前&#xff0c;最好先更新系统&#xff0c;以确保所有依赖都是最新的。打开终端&#xff08;Terminal&#xff09;并运行以下命令&#xff1a; sudo apt update sudo apt upgrade关闭Nouveau驱动: Nouveau是Nvidia显卡的开源驱动&#xf…

Linux系统使用ESP8266开发板(CP2102)

连接ESP8266开发板到电脑 虚拟机选择开发板硬件连接 查看USB连接情况: lsusb 授权USB接口访问 成功连接 编译项目 上传到开发板 成功提供WIFI热点服务

跳跃游戏 + 45. 跳跃游戏 II

给你一个非负整数数组 nums &#xff0c;你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标&#xff0c;如果可以&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 示例 1&#xff1a; 输…

动态SQL学习及使用场景(简略)

假设我们有一个商品表&#xff0c;包含id、name、price和category四个字段。现在需要实现修改商品价格的功能&#xff0c;我们可以使用动态SQL实现。 首先&#xff0c;我们需要构造一个SQL语句&#xff0c;根据用户提供的参数来动态生成&#xff0c;具体实现如下&#xff1a; …