news 2026/3/19 9:17:25

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/3/19 7:47:09

Android 数据库操作线程安全吗

一、原生 SQLite 的线程安全&#xff1a;需手动保障 Android 底层的 SQLiteDatabase 并非「开箱即用」的线程安全&#xff0c;核心规则如下&#xff1a;SQLite 本身的线程模式&#xff1a; SQLite 有 3 种线程模式&#xff0c;Android 系统默认编译为「多线程模式&#xff08;M…

作者头像 李华
网站建设 2026/3/16 2:36:19

Bazzite操作系统完整安装指南:打造终极Linux游戏体验

Bazzite操作系统完整安装指南&#xff1a;打造终极Linux游戏体验 【免费下载链接】bazzite Bazzite is an OCI image that serves as an alternative operating system for the Steam Deck, and a ready-to-game SteamOS-like for desktop computers, living room home theater…

作者头像 李华
网站建设 2026/3/14 7:27:00

FreeCAD尺寸标注插件实战指南:从零开始掌握工程绘图技巧

FreeCAD尺寸标注插件实战指南&#xff1a;从零开始掌握工程绘图技巧 【免费下载链接】FreeCAD_drawing_dimensioning Drawing dimensioning workbench for FreeCAD v0.16 项目地址: https://gitcode.com/gh_mirrors/fr/FreeCAD_drawing_dimensioning 还在为FreeCAD的尺寸…

作者头像 李华
网站建设 2026/3/13 19:03:20

智慧水务设备怎么选?4 大场景差异化设计,精准破解排水难题

城市排水系统的 “地下脉络” 里&#xff0c;雨污分流管网、合流制管网、排水泵站、河道排水口各司其职&#xff0c;却面临着截然不同的痛点 —— 有的要防混流&#xff0c;有的要控溢流&#xff0c;有的要保运行&#xff0c;有的要守水质。盲目选设备只会造成功能浪费或效果打…

作者头像 李华
网站建设 2026/3/13 21:57:42

html+CSS 20种钻石纹理背景,你应该是没见过的。值得收藏

有的时候简单的广告条&#xff0c;或部分区块&#xff0c;不想弄背景图&#xff0c;只好用css来实现。 但大多数人应该都会认为css实现的背景也就是各种渐变了。 那么看看下面的样式&#xff0c;怎么样&#xff1f; 这有个别的效果是动画效果&#xff0c;颜色不停的变幻。所以…

作者头像 李华
网站建设 2026/3/14 12:55:53

35岁以上的项目经理,可以开始考虑新的出路了!

35岁中年危机&#xff0c;一直是职场人绕不开的焦虑&#xff0c;对项目经理来说更是如此。一边是年轻人源源不断地进来&#xff0c;他们精力足&#xff0c;对新工具、新技术也敏感&#xff1b;另一边是年龄问题带来的职场瓶颈——经验不少但不知道怎么变现更值钱&#xff0c;或…

作者头像 李华