当前位置: 首页 > news >正文

专业网站建设服务公司哪家好发外链软件

专业网站建设服务公司哪家好,发外链软件,济南行知网站制作,仪表东莞网站建设翻译: 主要思路解释 整体思路概述: 本题的目标是给定整数(要删除的数字个数)和整数(以字符串形式表示的数字),通过合理删除个数字,使得最终得到的新数字最小。程序采用了一种贪心算…

翻译: 

主要思路解释

  1. 整体思路概述
    • 本题的目标是给定整数(要删除的数字个数)和整数(以字符串形式表示的数字),通过合理删除个数字,使得最终得到的新数字最小。程序采用了一种贪心算法的思想,从左到右遍历数字字符串,每次尝试删除能使当前数字变小的高位数字,经过多次这样的操作以及一些边界情况处理后,输出最终得到的最小数字字符串表示的结果。
  2. 输入与初始化部分
    • 首先定义了多个变量,包括用于存储测试用例数量的、每个测试用例中要删除数字个数的、数字字符串长度的以及用于循环计数的和等,同时定义了字符数组用于存储输入的数字字符串。通过scanf函数读取测试用例的数量,然后进入外层while循环处理每个测试用例。在每个测试用例中,先读取要删除的数字个数和数字字符串,接着使用strlen函数获取字符串 (n的长度并存储到len` 变量中。
  3. 核心处理逻辑部分(寻找并删除数字)
    • 外层for循环用于遍历数字字符串(除了最后一个字符,因为比较时是和下一个字符对比),在循环中,对于每个字符位置 (i,判断如果当前字符n[i]大于下一个字符n[i + 1],并且还有可删除的数字(m不等于0),这意味着删除当前字符可以使得到的新数字更小。此时,通过内层for循环将当前字符后面的所有字符依次向前移动一位n[j] = n[j + 1]),实现删除当前字符的效果,然后将字符串长度len减1(因为删除了一个字符),可删除数字个数m也减1。为了确保能重新从字符串开头开始检查是否还有可删除的能使数字变小的字符,将i重置为 -1,并且如果此时已经删除了足够数量的数字(m变为0),就直接跳出外层for` 循环,不再继续寻找可删除的数字了。
  4. 处理前导零及输出结果部分
    • 首先通过一个while循环找到处理后的字符串中第一个非零字符的位置,存储到变量a中,跳过前面可能存在的连续的 0。然后通过一个for循环从第一个非零字符位置a开始,到len - m结束(因为已经删除了m个字符),逐个输出剩余字符串的字符,这就是最终得到的删除m个数字后的数字字符串表示。最后,再判断如果第一个非零字符的位置a大于等于剩余字符串的长度(len - m),说明剩下的字符串全是 0 或者为空,此时输出 0 作为最终结果,并且每个测试用例输出完结果后进行换行操作,以便下一个测试用例的结果能正确显示,持续处理所有测试用例,直到全部处理完毕。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>int main()
{int T, m, len, i, j;  // T用于存储测试用例的数量,m表示每个测试用例中要删除的数字个数,len用于记录输入数字字符串的长度,i、j主要用于循环计数char n[1002];  // 定义字符数组n,用于存储输入的数字字符串,大小设为1002,可根据题目中数字字符串长度的限制进行合理设置// 读取测试用例的数量Tscanf("%d", &T);// 外层while循环,针对每个测试用例进行处理,每处理完一个测试用例,T减1,直到所有测试用例都处理完while (T--){// 读取当前测试用例中要删除的数字个数m以及数字字符串nscanf("%d%s", &m, &n);len = strlen(n);  // 获取输入数字字符串n的长度// 如果要删除的数字个数m大于等于字符串的长度len,说明要删除的数字太多,直接输出0,并通过continue跳过当前测试用例后续的处理步骤,直接进入下一个测试用例的处理if (m >= len){printf("0\n");continue;}// 外层for循环用于遍历数字字符串(除了最后一个字符,因为比较时是和下一个字符对比),尝试找到可以删除的数字,以得到最小的新数字for (i = 0; i < len - 1; i++){// 如果当前字符大于下一个字符,且还有可删除的数字(m不等于0),说明可以通过删除当前字符来使得到的新数字更小if (n[i] > n[i + 1] && m!= 0){// 内层for循环,将当前字符后面的所有字符依次向前移动一位,实现删除当前字符的效果for (j = i; j < len - 1; j++){n[j] = n[j + 1];}len--;  // 字符串长度减1,因为删除了一个字符m--;  // 可删除的数字个数减1i = -1;  // 将i重置为 -1,使得下一次循环时会重新从字符串开头开始遍历,因为前面的字符位置发生了变化,需要重新检查if (m == 0)  // 如果已经删除了足够数量的数字(m变为0),就不需要再继续遍历寻找可删除的数字了,直接跳出循环break;}}int a = 0;// 这个循环用于找到处理后的字符串中第一个非零字符的位置,跳过前面可能存在的连续的0while (n[a] == '0'){a++;}// 循环输出删除m个数字后剩下的字符串内容,从第一个非零字符位置a开始,到len - m结束(因为已经删除了m个字符)for (i = a; i < len - m; i++){printf("%c", n[i]);}// 如果经过前面的处理后,第一个非零字符的位置a大于等于剩余字符串的长度(len - m),说明剩下的字符串全是0或者为空,此时输出0if (a >= len - m){printf("0");}printf("\n");  // 每个测试用例输出完结果后进行换行,以便下一个测试用例的结果能正确显示}return 0;
}

http://www.hengruixuexiao.com/news/40350.html

相关文章:

  • 北京网站设计优刻试分析网站推广和优化的原因
  • 网站建设计划方案cba排名
  • 找人做网站怎么做友情链接qq群
  • 湖南营销型网站建设 干净磐石网络深圳seo招聘
  • 网站建设需要些什么网络推广和运营的区别
  • 某高校门户网站开发案例seo知识总结
  • 互联网是做什么工作的seo短视频网页入口引流网站
  • 保山网站制作浏览器网站进入口
  • 宝安专业网站设计公司网络运营培训
  • 网站防劫持怎么做上海网站推广排名公司
  • 网站快捷按钮以什么方式做上海专业排名优化公司
  • 如何做地图的ppt模板下载网站新开传奇网站发布站
  • 怎样做自己公司的网站西安seo网络优化公司
  • 专业做农牧应聘的网站百度店铺
  • 济南网站建设bajiujiuseo视频
  • 深圳品牌营销型网站建设免费seo关键词优化方案
  • 网站备案网站名称seo博客大全
  • 网站设计制作一条龙免费采集站seo提高收录
  • 衢州网站建设平台策划是做什么的
  • 预约代码 wordpress什么软件可以优化关键词
  • 广州设计网站培训班企业培训课程推荐
  • 建设实验教学网站的作用百度指数官方网站
  • 酷站网优化推广网站seo
  • 腾冲做兼职的网站绍兴seo排名外包
  • h5 做的网站 价格免费网站推广群发软件
  • 网站建设需求确定怎么去做网络推广
  • 怎么建设企业网站seo软件下载
  • 珠海网站建设制作怎么收费厦门seo网站管理
  • 飞创网站建设移动端关键词优化
  • 备案用网站建设方案书宁波seo关键词排名优化