PAT A1038 Recover the Smallest Number ——醉里挑灯看剑

PAT A1038 Recover the Smallest Number

  • 犯的错误在于只考虑了第一个数字的前导0,以及结果为零的时候没有输出,应该是把最终结果的前导0都抹掉,如果都抹没了就输出0,但是只挂了一个测试点,恩,测试点考虑不周~
  • cmp的想法就是逐位比较两个数,当发现有一位不相等时,把小的排在前面,此时会有两个数位数不同的情况,经过模拟发现可以把短的循环使用,比如32和321,32扩展成3232,所以跟1比较的应该是3;32和323212,32扩展成323232,所以323212胜出
  • 但是看过书上的解法之后,感觉自己就是个二傻子,直接return a+b < b+a 就行了。。。
#include <iostream>
#include <algorithm>
#include <string>
#include <vector>
#include <queue>
#include <math.h>
#include <set>
#include <map>
#include <unordered_map>
#include <stack>


using namespace std;


#define MAXSIZE 10010

vector<string> vs;

bool cmp(string s1,string s2){
    
    int i = 0,j = 0;
    bool flag1 = false,flag2 = false;
    while(s1[i] == s2[j]){
        i ++;
        j ++;
        if(i == s1.length()){
            i = 0;
            flag1 = true;
        } 
        if(j == s2.length()){
            j = 0;
            flag2 = true;
        } 
        if(flag1 && flag2) return true;
    }
    return s1[i] < s2[j];
}

#define DEBUG 



int main(){

#ifdef DEBUG
	freopen("1.txt","r",stdin);	
#endif

    int num;
    cin >> num;
    for(int i = 0;i < num;i ++){
        string tmp;
        cin >> tmp;
        vs.push_back(tmp);
    }
    sort(vs.begin(),vs.end(),cmp);
    /*
    for(int i = 0;i < vs.size();i ++){
        if(i == 0 && vs[i][0] == '0'){
            int j = 0;
            while(vs[i][j] == '0'){
                j ++;
            }
            for(;j < vs[i].length();j ++){
                cout << vs[i][j];
            }
        }else
            cout << vs[i];
    }
    */
    string ans = "";
    for(int i = 0;i < vs.size();i ++) ans += vs[i];		//拼接
    int i = 0;
    while(ans[i] == '0') i ++;				//抹去前导0
    if(i == ans.length()) cout << 0;		//抹没了输出0
    for(;i < ans.length();i ++){			//还有的话就输出剩下的
        cout << ans[i];
    }
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DB历史主题丢失是指数据库历史记录的主题内容不见了。这种情况下,我们可以尝试通过重新配置来恢复它。 首先,我们需要检查数据库配置文件,确保历史记录功能没有被禁用或配置错误。检查配置文件中与历史记录相关的参数设置,如历史记录的保留时间、历史记录文件的存储位置等。如果这些参数设置正确,但历史主题仍然丢失,我们可以尝试以下步骤进行恢复。 1. 停止数据库服务:首先,需要停止正在运行的数据库服务,以便执行下一步的操作。 2. 备份数据库:在进行任何恢复操作之前,务必先备份数据库文件,以防止意外数据丢失。 3. 清空历史记录相关文件:进入数据库目录,并删除与历史记录相关的文件,如历史记录日志文件、历史记录索引文件等。这样做的目的是清除之前可能存在的损坏的历史记录文件。 4. 重新配置数据库:编辑数据库配置文件,重新启用历史记录功能并确保相应的参数设置正确。 5. 启动数据库服务:保存更改后,重新启动数据库服务,让新的配置生效。 6. 监视恢复进程:在数据库启动后,我们可以通过监视日志或使用数据库管理工具,验证历史记录是否被正确恢复。可以查看历史记录是否开始重新生成,以及检查历史记录文件是否存在以及大小是否与预期一致。 7. 测试恢复结果:使用数据库客户端连接到数据库,并执行一些操作,以验证历史记录是否正常工作。可以查询历史记录文件,查看相应的操作是否已被记录。 总之,当DB历史主题丢失时,我们可以尝试通过重新配置数据库来恢复它。这个过程需要注意备份数据、重要文件的清除和重新配置以及验证恢复结果等步骤,以确保恢复过程顺利且有效。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值