news 2026/4/16 12:55:10

OJ刷题小结(12.11)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
OJ刷题小结(12.11)

题目1: 星图演化的总亮度(快速幂,第四次比赛补题)

问题:

思路:

由题目可推出n级的所有星图总亮度之和为,n的范围过大,还需要大数取模。而快速幂的时间复杂度低,仅有O(logn),并且适用于大数取模(模幂运算),它可以在每一步都取模,避免中间结果溢出,并保证结果正确,故使用快速幂算法(详情看C知识点专栏第二篇)

代码:

#include <stdio.h> #include <stdlib.h> //题目翻译:求3^n*2^n,相当于求6^n,考虑递归快速幂 const long long MOD=1000000007; long long qpow(long long n){ if(n==0){ return 1; } else if(n%2==1){ return (qpow(n-1)*6)%MOD; } else{ long long t=qpow(n/2); return (t*t)%MOD; } } int main() { long long n; scanf("%lld",&n); printf("%lld",qpow(n)); return 0; }

题目2:字符串翻转

问题:

思路:

分奇偶来考虑,n为偶数,则将字符串分为二段来输出,每段各输出n/2个字符;

n为奇数,则将字符串分为三段来输出,第一段输出前n/2个,第二段输出一个(最中间),第三段输出后n/2个

注意:单个字符输出用%c,%s期望的是一个\0结尾的字符数组的首地址

%s:用于字符串(字符数组)

🔹 含义

  • 读取或输出以空字符\0结尾的字符序列

  • 自动跳过开头的空白字符

  • 遇到空白字符(空格、\n、\t)就停止读取

代码:

#include <stdio.h> #include <stdlib.h> #include <string.h> int main() { char str[100]; scanf("%s",str); int n; n=strlen(str); int idx=n/2; if(!(n%2)){ for(int i=idx-1;i>=0;i--){ printf("%c",str[i]); } for(int i=n-1;i>=idx;i--){ printf("%c",str[i]); } } else{ for(int i=idx-1;i>=0;i--){ printf("%c",str[i]); } printf("%c",str[idx]); for(int i=n-1;i>=idx+1;i--){ printf("%c",str[i]); } } // fdsa glkj n/2-1~0 n-1~n/2 闭区间 // fas a glk n/2-1~0 n/2 n-1~n/2+1 闭区间 return 0; }

题目3:up,up,up!!!(第四次比赛补题)

问题:

思路:

代码:

#include <stdio.h> #include <stdlib.h> int main() { int T; scanf("%d",&T); while(T--){ int n; scanf("%d",&n); int *num=malloc(sizeof(int)*n); for(int i=0;i<n;i++){ scanf("%d",&num[i]); } int issame=0; for(int i=0;i<n-1;i++){ for(int j=i+1;j<n;j++){ if(num[j]==num[i]){ issame=1; } } } if(issame){ printf("NO\n"); } else{ printf("YES\n"); } free(num); } return 0; }

题目4:zwz买装备哦(第四次补题)

问题:

思路:

逐个比较

代码:

#include <stdio.h> int main() { int n, x, y, z, t; scanf("%d %d %d %d %d", &n, &x, &y, &z, &t); int ans=x+y; // 不换装备的战斗力 int money=t+z; // 卖掉旧装备后的总钱数 for (int i=0;i<n;i++) { int a,b,c; scanf("%d %d %d",&a,&b,&c); if(c<=money){ int power=a+b; if(power>ans) { ans=power; } } } printf("%d\n",ans); return 0; }

题目5:qqq的好数组(第四次补题)

问题:

思路:

二个数字,如果它们%q都相等,那么他们一定能通过有限次+q的操作达到相等

代码:

#include <stdio.h> #include <stdlib.h> int main() { int n,q; scanf("%d %d",&n,&q); int *num=malloc(sizeof(int)*n); for(int i=0;i<n;i++){ scanf("%d",&num[i]); } int a=1; int y=num[0]%q; for(int i=1;i<n;i++){ if((num[i]%q)!=y){ a=0; break; } } if(a) printf("YES"); else printf("NO"); free(num); return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 13:29:10

JienDa聊PHP:从Laravel到ThinkPHP的现代Web开发实践

一、引言&#xff1a;PHP框架的演进与现状 PHP作为全球最流行的服务器端脚本语言之一&#xff0c;自1994年诞生以来&#xff0c;已经走过了近30年的发展历程。在这期间&#xff0c;PHP生态系统经历了从过程式编程到面向对象编程&#xff0c;再到现代框架化开发的演进过程。当前…

作者头像 李华
网站建设 2026/4/16 13:37:20

CSS 盒子模型:万物皆是盒子

- 生活中的例子 01 设计一个按钮&#xff0c;让里面的文字不要紧贴着边缘&#xff08;使用内边距&#xff09;。 - 生活中的例子 02 给一张照片加上黑色的边框&#xff0c;让它看起来像拍立得&#xff08;使用边框&#xff09;。 - 生活中的例子 03 让两段文字之间保持舒适的阅…

作者头像 李华
网站建设 2026/4/16 15:10:02

为什么顶尖量子工程师都在用VSCode做电路可视化?

第一章&#xff1a;为什么顶尖量子工程师都在用VSCode做电路可视化&#xff1f;量子计算正从理论走向工程实践&#xff0c;而量子电路的可视化成为开发过程中的关键环节。越来越多的顶尖量子工程师选择 Visual Studio Code&#xff08;VSCode&#xff09;作为核心开发环境&…

作者头像 李华
网站建设 2026/4/16 13:31:21

CY5-naltrexone,CY5-纳曲酮,远红荧光纳曲酮探针

CY5-naltrexone&#xff0c;CY5-纳曲酮&#xff0c;远红荧光纳曲酮探针中文名称&#xff1a;CY5-标记纳曲酮&#xff08;CY5-Naltrexone&#xff09; &#xff08;其他称法&#xff1a;纳曲酮-CY5、CY5-Naltrexone 荧光衍生物、远红荧光纳曲酮探针&#xff09;CY5-纳曲酮是一种…

作者头像 李华
网站建设 2026/4/16 13:29:44

Typora OneDark主题:让深夜写作不再伤眼的智能暗色解决方案

Typora OneDark主题&#xff1a;让深夜写作不再伤眼的智能暗色解决方案 【免费下载链接】typora-onedark-theme A dark theme for Typora inspired by VScodes One Dark Pro theme. 项目地址: https://gitcode.com/gh_mirrors/ty/typora-onedark-theme 还在为深夜码字时…

作者头像 李华
网站建设 2026/4/16 14:11:29

会议室LED显示屏扩声系统生产制作

会议室LED显示屏扩声系统生产制作&#xff1a;技术集成与北京瓴地科技有限公司的实践在现代智能会议室的建设中&#xff0c;会议室LED显示屏扩声系统 已成为提升会议效率与沟通体验的核心组件。其生产制作并非简单的硬件堆砌&#xff0c;而是一项涉及光电技术、声学设计、信号处…

作者头像 李华