力扣刷题day1(两数相加,回文数,罗马数转整数)

题目1:1.两数之和

思路1和解析:

//1.暴力枚举解法(历遍两次数组,时间复杂度O(N^2),空间复杂度O(1)
int* twoSum(int* nums, int numsSize, int target, int* returnSize) 
{for (int i = 0; i < numsSize; ++i) //从数组第一个位置开始{for (int j = i + 1; j < numsSize; ++j)//从固定位置的下一个位置开始找{if (nums[i] + nums[j] == target) //找到的时候{int* ret = malloc(sizeof(int) * 2);//在内存中分配足够的空间用来存储两个整数的大小,并将指向这块空间的指针赋值给了ret。//换句话说,这行代码使用了C语言中的malloc函数来动态分配了两个整数大小的内存空间,并将指向这块内存空间的指针保存在了ret变量中。ret[0] = i, ret[1] = j;//将变量i的值存储在ret指向的内存空间的第一个位置,j存在第二个位置*returnSize = 2;//将包含数组大小的值设置为2return ret;//返回指向数组的指针ret}}}*returnSize = 0;return NULL;//不存在,返回空指针
}

 思路2和解析:

// 向哈希表中插入新条目或更新现有条目
void insert(int ikey, int ival)
{struct hashTable* it = find(ikey); // 查找具有指定键的条目if (it == NULL) // 如果条目不存在{struct hashTable* tmp = malloc(sizeof(struct hashTable)); // 分配内存以创建新条目tmp->key = ikey, tmp->val = ival; // 设置新条目的键和值HASH_ADD_INT(hashtable, key, tmp); // 将新条目添加到哈希表中}else // 如果条目已经存在{it->val = ival; // 更新现有条目的值}
}// 在数组中查找两个数字,使它们的和等于目标值
int* twoSum(int* nums, int numsSize, int target, int* returnSize)
{hashtable = NULL; // 初始化哈希表for (int i = 0; i < numsSize; i++) // 遍历输入数组{struct hashTable* it = find(target - nums[i]); // 查找当前数字的补数在哈希表中是否存在if (it != NULL) // 如果在哈希表中找到了补数{int* ret = malloc(sizeof(int) * 2); // 分配内存以创建结果数组ret[0] = it->val, ret[1] = i; // 设置结果数组为找到的两个数字的索引*returnSize = 2; // 设置返回数组的大小为2return ret; // 返回结果数组}insert(nums[i], i); // 将当前数字及其索引插入哈希表}*returnSize = 0; // 如果没有找到解,则将返回数组的大小设置为0return NULL; // 返回NULL
}

题目2:9.回文数

思路1和解析:

//回文数
//1.
bool isPalindrome(int x)
{if (x < 0)return false;//因为负数不可能是一个回文数long int a, b = 0;//创建变量,注意变量范围a = x;//存储a值//逆序求值,如果相当说明是回文数while (a != 0){b = b * 10 + a % 10;a = a / 10;}if (x == b)return true;elsereturn false;
}

思路2和解析:

//2.
bool isPalindrome(int x)
{char s[20];int i;sprintf(s, "%d", x);//将字符类型转换为整型int l = strlen(s);//计算长度for (i = 0; i < l / 2; i++){if (s[i] != s[l - i - 1])//看对应位上的数字是否相当,如果是奇数位,中间位不用管{return false;//发现不相当就不是回文数,反之就是}}return true;
}

题目3:13.罗马数字转整数

思路和解析: 

//罗马数字转整数
int getHash(char c) //传入字符
{switch (c) //根据传入字符选择对应的值{case 'I':return 1;case 'V':return 5;case 'X':return 10;case 'L':return 50;case 'C':return 100;case 'D':return 500;case 'M':return 1000;default:return 0;}
}int romanToInt(char* s) 
{int ret = 0;//创建个变量用来存储值for (int i = 0; s[i]; i++) {if (getHash(s[i]) < getHash(s[i + 1])){ret += (-getHash(s[i]));//小于的时候,比如IV,I<V,IV是4,就是V-I}else//反之就是大于,不存在特殊情况,直接加上去就行{ret += getHash(s[i]);}/* ret += getHash(s[i]) < getHash(s[i + 1]) ? -getHash(s[i]) : getHash(s[i]);*/}return ret;
}

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

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

相关文章

【Selenium+Webmagic】基于JAVA语言实现爬取js渲染后的页面,附有代码

事先声明 笔者最近需要查看一些数据&#xff0c;自己挨个找太麻烦了&#xff0c;于是简单的学了一下爬虫。笔者在这里声明&#xff0c;爬的数据只为学术用&#xff0c;没有其他用途&#xff0c;希望来这篇文章学习的同学能抱有同样的目的。 枪本身不坏&#xff0c;坏的是使用枪…

Naco安装、配置、使用request接口交互

1. Docker安装Naco 官方文档https://nacos.io/zh-cn/docs/quick-start-docker.html&#xff0c;然而自己部署的时候遇到了“Database not set”的问题。有可能是因为环境中已经部署了3306的mysql服务导致的。&#xff08;虽然我尝试修改了naco的docker-compose&#xff0c;但是…

如何制作教育培训小程序

教育培训行业近年来发展迅速&#xff0c;越来越多的机构开始意识到通过小程序来提供在线教育服务的重要性。小程序不仅可以为用户提供便捷的学习体验&#xff0c;还可以增加机构的知名度和品牌影响力。那么&#xff0c;如何制作一款教育培训小程序呢&#xff1f; 首先&#xff…

WT2605C语音芯片:实现蓝牙音频播放与BLE透传,引领智能设备应用新潮流

随着蓝牙技术的快速发展&#xff0c;蓝牙音频播放和BLE&#xff08;蓝牙低功耗&#xff09;透传已成为智能设备中不可或缺的功能。在这样的背景下&#xff0c;WT2605C语音芯片以其出色的性能和集成度&#xff0c;完美实现了蓝牙音频播放BLE透传的功能&#xff0c;为智能设备的应…

【例1.6】回文数(Noip1999)

1309&#xff1a;【例1.6】回文数(Noip1999) 时间限制: 1000 ms 内存限制: 65536 KB 【题目描述】 若一个数&#xff08;首位不为零&#xff09;从左向右读与从右向左读都是一样&#xff0c;我们就将其称之为回文数。例如&#xff1a;给定一个 10进制数 56&#xff0c;将 56加…

using meta-SQL 使用元SQL 六

%Table Syntax %Table(recname) Description Use the %Table construct to return the SQL table name for the record specified with recname. 使用%Table构造返回使用recname指定的记录的SQL表名。 This construct can be used to specify temporary tables for runn…

sqlmap400报错问题解决

python sqlmap.py -r sql.txt --batch --techniqueB --tamperspace2comment --risk 3 --force-ssl–batch 选项全部默认 不用再手动输入 –techniqueB 使用布尔盲注&#xff0c;该参数是指出要求使用的注入方式 –tamperspace2comment使用特殊脚本&#xff0c;space2comment是把…

【MySQL语言汇总[DQL,DDL,DCL,DML]以及使用python连接数据库进行其他操作】

MySQL语言汇总[DQL,DDL,DCL,DML] SQL分类1.DDL:操作数据库&#xff0c;表创建 删除 查询 修改对数据库的操作对表的操作复制表&#xff08;重点&#xff09;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 2.DML:增删改表中数据3.DQL&#xff1a;查询表中的记录…

jsp在线辅助教育系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 JSP 在线辅助教育系统是一套完善的java web信息管理系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开发&#xff0c;数据库为Mysql5.0&…

工厂生产数据展示基本布局Demo(提供素材)

效果图&#xff1a; <template><div class"app-container"><a-row :span"24"><a-col :span"12"><div class"divBox"><div class"flexBoxs"><div style"margin: 2px 5px;"…

在windows server系统下,快速部署自己的网站

目录 xampp简介xampp的作用xampp的安装方法Apache简介Apache的作用 本文主要介绍使用xampp软件包在windows server系统下&#xff0c;快速部署自己的网站。 xampp简介 XAMPP是一款基于Apache、MySQL、PHP和Perl的开源Web服务器软件包。XAMPP支持多个操作系统&#xff0c;包括W…

go写文件后出现大量NUL字符问题记录

目录 背景 看看修改前 修改后 原因 背景 写文件完成后发现&#xff1a; size明显也和正常的不相等。 看看修改前 buf : make([]byte, 64) buffer : bytes.NewBuffer(buf)// ...其它逻辑使得buffer有值// 打开即将要写入的文件&#xff0c;不存在则创建 f, err : os.Open…

MySQL数据备份

一、逻辑备份 备份的是建表、建库、插入等操作所执行SQL语句&#xff0c;适用于中小型数据库&#xff0c;效率相对较低。 本质&#xff1a;导出的是SQL语句文件 优点&#xff1a;不论是什么存储引擎&#xff0c;都可以用mysqldump备成SQL语句 缺点&#xff1a;速度较慢&…

Mysql分布式集群部署---MySQL集群Cluster将数据分成多个片段,每个片段存储在不同的服务器上

1.1 目的 部署MysqlCluster集群环境 1.2 MySQL集群Cluster原理 1 数据分片 MySQL集群Cluster将数据分成多个片段&#xff0c;每个片段存储在不同的服务器上。这样可以将数据负载分散到多个服务器上&#xff0c;提高系统的性能和可扩展性。 2. 数据同步 MySQL集群Cluster使…

前端面试理论题

1.什么是js&#xff1f;js的特点是什么&#xff1f; js&#xff1a; 是一种直译式脚本语言&#xff0c;是一种动态类型、弱类型、基于原型的高级语言。 特点&#xff1a;简单性&#xff1b;安全性&#xff1b;动态性&#xff1b;跨平台性&#xff1b; 简单性&#xff1a;它的…

ElasticSearch之Close index API

关闭指定的索引。 索引关闭之后&#xff1a; 停止对读、写操作的响应。停止检索操作的响应。在索引关闭前&#xff0c;允许执行的操作&#xff0c;关闭之后均不允许执行。ElasticSearch取消对索引的相关维护操作&#xff0c;包含内存中的数据结构&#xff0c;以及保存在存储中…

c++--运算符重载

1.重载的运算符 (1).重载运算符函数的参数数量与该运算符作用的运算对象数量一样多。 (2).除了重载的函数调用运算符operator()之外&#xff0c;其他重载运算符不能含有默认实参。 (3).对一个重载的运算符&#xff0c;其优先级和结合律与对应的内置运算符保持一致。 (4).当一个…

2022年全国大学生数据分析大赛医药电商销售数据分析求解全过程论文及程序

2022年全国大学生数据分析大赛 医药电商销售数据分析 原题再现&#xff1a; 问题背景   20 世纪 90 年代是电子数据交换时代&#xff0c;中国电子商务开始起步并初见雏形&#xff0c;随后 Web 技术爆炸式成长使电子商务处于蓬勃发展阶段&#xff0c;目前互联网信息碎片化以…

破解研发人员的绩效考核难题

当下的中国正处于产业结构调整的重要转型时期。创新成为当下企业寻求稳健和长远发展必不可少的关键。要建立属于自己的企业特色&#xff0c;开发出属于自己的产品和服务并在激励竞争的市场下求得生存和发展&#xff0c;企业的自主研发活动已经越来越重视。纵观那些世界500强企业…

【Centos】在CentOS上搭建Squid代理服务器详解

在CentOS上搭建Squid代理服务器详解 一、安装 首先&#xff0c;通过yum包管理工具安装Squid代理服务器和httpd-tools&#xff08;用于生成密码文件&#xff09;&#xff1a; yum install squid -y yum install httpd-tools -y二、生成密码文件 创建用于存储用户认证信息的目…