news 2026/6/10 15:45:42

C语言之小果的键盘

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C语言之小果的键盘

题目背景

小果有一个只有两个键的键盘。

题目描述

一天,她打出了一个只有这两个字符的字符串。当这个字符串里含有VK这个字符串的时候,小果就特别喜欢这个字符串。所以,她想改变至多一个字符(或者不做任何改变)来最大化这个字符串内VK出现的次数。给出原来的字符串,请计算她最多能使这个字符串内出现多少次VK(只有当VK正好相邻时,我们认为出现了VK。)

输入格式

第一行给出一个数字 n,代表字符串的长度。

第二行给出一个字符串 s。

输出格式

第一行输出一个整数代表所求答案。

思考历程

又没有好好看题目意思,题目要求的是最多改变一个字符,要求出现最多的vk,一开始没有考虑直接写,分可低了。下面的代码没有考虑左右字符的影响,没有考虑边界情况,所以肯定不对

#include<stdio.h> int main() { int n; while(scanf("%d",&n)!=EOF){ while(getchar()!='\n'); char s[n+1]; fgets(s,sizeof(s),stdin); int i; int count=0; for(i=0;i<n-1;i++){ if(s[i]=='V'&&s[i+1]=='K'||s[i]=='K'&&s[i+1]=='V'){ count++; } } printf("%d",count); } return 0; }

正确答案:

#include<stdio.h> #include<string.h> int main() { int n; char s[101];//千万注意不要写成int类型 while(scanf("%d",&n)==1&&n!=0){ scanf("%s",s);//把字符串赋值给字符串数组 int i; int original_count=0;//没改字符之前统计的vk数量 for(i=0;i<n-1;i++){ if(s[i]=='V'&&s[i+1]=='K'){ original_count++; } } int max_delta=0; for(i=0;i<n;i++){ char old_char=s[i];//把所有的字符赋值给old_char,用于记录当前位置原来的字符 char new_char=(old_char=='V')?'K':'V';//改变字符,如果是v就改成k,如果是k就改成v。 int delta=0;//计算变化量 if(i-1>=0){//因为i=0时没有s[i-1] int old1_is_vk=(s[i-1]=='V'&&old_char=='K'); int new1_is_vk=(s[i-1]=='V'&&new_char=='K'); delta+=(new1_is_vk?1:0)-(old1_is_vk?1:0);//计算vk组合新增加的数量。 } if(i+1<n){//因为有i+1,不能超过n,一开始的i=0肯定不满足上述条件 int old2_is_vk=(old_char=='V'&&s[i+1]=='K'); int new2_is_vk=(new_char=='V'&&s[i+1]=='K'); delta+=(new2_is_vk?1:0)-(old2_is_vk?1:0); } if(delta>max_delta){//因为最后要找出改变字符后的最大组合量,所以要和原来有比较 max_delta=delta; } } int result=original_count+(max_delta>0?max_delta:0);max_delta表示的是改变字符后新增加的组合量 printf("%d\n",result); } return 0; }

一.上述代码是模拟修改,不是真的修改,所以不满足条件的不用再修改回来

因为修改一个字符影响的是和前一个字符配对,和后一个字符配对,所以只需要考虑这两部分即可。(i-1,i)和(i,i+1)这两部分。当考虑到这两部分之后,就要考虑i-1必须要大于0,i+1必须要小于0.

for(i=0;i<n;i++){
char old_char=s[i];
char new_char=(old_char=='V')?'K':'V';
int delta=0;
if(i-1>=0){
int old1_is_vk=(s[i-1]=='V'&&old_char=='K');
int new1_is_vk=(s[i-1]=='V'&&new_char=='K');
delta+=(new1_is_vk?1:0)-(old1_is_vk?1:0);
}
if(i+1<n){
int old2_is_vk=(old_char=='V'&&s[i+1]=='K');
int new2_is_vk=(new_char=='V'&&s[i+1]=='K');
delta+=(new2_is_vk?1:0)-(old2_is_vk?1:0);
}

用示例来解析上述代码:

假设字符串是VVK

第一次循环i=0,考虑修改第一个字符

old_char = s[0] = 'V' new_char = 'K' // V改为K // 计算改变影响: // 只有(i,i+1)即(0,1)受影响 // 改变前:'V'(old)和'V'(s[1]) → "VV" 不是VK // 改变后:'K'(new)和'V'(s[1]) → "KV" 不是VK // delta = 0-0 = 0 //上述部分只符合下面的if语句,所以只有一部分delta

第二次循环i=1,考虑修改第二个字符

old_char = s[1] = 'V' new_char = 'K' // V改为K // 计算改变影响: // (i-1,i)即(0,1):改变前"VV"(0),改变后"VK"(+1) → delta_part1 = 1 // (i,i+1)即(1,2):改变前"VK"(1),改变后"KK"(0) → delta_part2 = -1 // total_delta = 1 + (-1) = 0 //当改变第二个字符的时候,既符合上述if语句,又符合下面的if语句,所以有两部分delta,原来是VV,不符合上述判断vk,所以old1_is_vk=0,而修改第二个字符之后变成VK,符合杉树判断,所以第一部分delta是1,同时下面的if同样计算,最后得出总的delta

第三次循环i=2,考虑修改第三个字符

old_char = s[2] = 'K' new_char = 'V' // K改为V // 计算改变影响: // 只有(i-1,i)即(1,2)受影响 // 改变前:'V'(s[1])和'K'(old) → "VK" 是VK // 改变后:'V'(s[1])和'V'(new) → "VV" 不是VK // delta = 0-1 = -1 //i=2时只符合上述if语句,所以只计算一次就🆗
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 12:35:01

互联网大厂求职面试:Java小白的成长之路

文章标题&#xff1a; 互联网大厂求职面试&#xff1a;Java小白的成长之路 文章简述&#xff1a; 本文讲述了一位名叫“超好吃”的Java小白在互联网大厂求职面试中的故事。通过三轮提问&#xff0c;面试官涵盖了Java核心技术栈、微服务、云原生等内容&#xff0c;帮助求职者在技…

作者头像 李华
网站建设 2026/6/10 12:27:21

AI虚拟恋人的伦理边界:情感依赖与主体性思考

虚拟恋人的情感依赖&#xff1a;从现象到成因虚拟恋人作为AI技术落地的典型场景&#xff0c;近年来伴随生成式AI的迭代实现了用户规模的快速增长。据某全球咨询机构2023年报告显示&#xff0c;AI伴侣类应用的月活用户较2022年增长47%&#xff0c;其中35%的用户日均互动时长超过…

作者头像 李华
网站建设 2026/6/10 12:33:38

Paperxie:当课程论文不再是 “每周深夜的突击”

paperxie-免费查重复率aigc检测/开题报告/毕业论文/智能排版/文献综述/aippt https://www.paperxie.cn/ai/coursePaperhttps://www.paperxie.cn/ai/coursePaper 周三晚上九点&#xff0c;我刚把选修课 “教育社会学” 的课件划到最后一页&#xff0c;手机日历的弹窗突然跳出来…

作者头像 李华
网站建设 2026/6/10 12:43:08

震惊!这家云服务器代理商性价比竟超厂家,背后真相曝光!

震惊&#xff01;这家云服务器代理商性价比竟超厂家&#xff0c;背后真相曝光&#xff01;在云计算服务市场竞争日趋白热化的今天&#xff0c;企业用户在选择云服务时&#xff0c;往往面临一个核心抉择&#xff1a;是直接向原厂采购&#xff0c;还是通过专业的代理商获取服务&a…

作者头像 李华
网站建设 2026/6/10 12:33:23

震惊!云服务器代理商选错,你的业务损失千万!

震惊&#xff01;云服务器代理商选错&#xff0c;你的业务损失千万&#xff01;在数字化转型的浪潮中&#xff0c;云服务器已成为企业运营的“数字心脏”。然而&#xff0c;许多企业在选择云服务时&#xff0c;往往将目光聚焦于头部云厂商的品牌光环&#xff0c;却忽略了连接企…

作者头像 李华
网站建设 2026/6/10 14:00:51

IO重定向

第一部分&#xff1a;重定向的本质 1. 核心规则&#xff1a;最小分配原则Linux 在 open 一个文件时&#xff0c;有一个铁律&#xff1a;给新文件分配的 fd&#xff0c;永远是当前 files_struct 数组中 最小的、未被占用的 下标。2. 手动实现重定向 ( The "Hack" Way …

作者头像 李华