问题 K: 周期串plus

本文介绍了一种用于确定给定字符串最小周期的算法实现。通过不断尝试不同长度的子串来判断其是否能构成原串的周期,最终输出最小周期长度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[提交] [状态] [命题人:外部导入]

题目描述

如果一个字符串可以由某个长度为k的字符串重复多次得到,我们说该串以k为周期。例如abcabcabcabc以3为周期(当然他也以6,12为周期)。输入一个长度不超过100000的串,输出他的最小周期。

 

输入

多组测试数据,每组仅一行为一个仅有大写字母组成的字符串。

 

输出

对于每组数据输出该字符串的最小周期。

样例输入

复制样例数据

HOHO

样例输出

2
#include <iostream>
#include <bits/stdc++.h>
using namespace std;
string str;
string flag;
char ch[100005];
int solve(int x)
{
    long long sum=x-1;
    string mid=str.substr(0,x);
    while(sum<str.size()-1)
    {
        flag=str.substr(sum+1,x);
        if(flag!=mid)
        {
            return sum+1;
        }
        sum+=x;
    }
    return -2;
}
int main()
{
    while(~scanf("%s",ch))
    {
        long long ans=0;
        str=ch;
        for(int i=1; i<=str.size(); i++)
        {
            ans=solve(i);
            if(ans==-2)
            {
                cout<<i<<endl;
                break;
            }
            i=ans;
        }
        getchar();
    }
    return 0;
}

 

%% step5:循环求解 for i=1:batch_size % 定义每个batch的需求量 if i==1 U=ui(1,:); else % if sum(U)>0 % disp (['有上个batch的剩余乘客']); % end U=U+ui(i,:); end [Zjk,Wk,G] = lastmile_model(phi_jk,tk,t_jk,U,beta1,beta2,beta3,K,J,c);%模型建立,求解推荐线路集合 % S = route_rank(Wk,tk,Zjk,phi_jk);%推荐线路优先级排序 S = route_rank2(Wk,tk,Zjk,phi_jk,btw,t,headway);%推荐线路优先级排序 Temp_S=S; [btw,S,U,total_trip,total_traveltime,total_waitingtime,totoal_ridingtime,btw_vehicle,chengke] = vehicle_dispatch(btw,t_jk,S,U,Zjk,t,headway,total_trip,total_traveltime,total_waitingtime,totoal_ridingtime,btw_vehicle,chengke);%车辆分配 if isempty(S) s(i).route=Temp_S; pax_asg(i).record=Zjk; else index=find(Temp_S(:,1)==S(1,1)); s(i).route=Temp_S(1:index-1,:); unfinished_route=S(:,1); Zjk(:,unfinished_route)=0; pax_asg(i).record=Zjk; end S=[];%清空推荐线路 t=t+headway;%分配时间段后移一个batch btw_record(:,i+1)=btw; end %如果还存在没有服务完的乘客,再运行一次 plus_trip=batch_size; while sum(U)>0 plus_trip=plus_trip+1; [Zjk,Wk,G] = lastmile_model(phi_jk,tk,t_jk,U,beta1,beta2,beta3,K,J,c);%模型建立,求解推荐线路集合 % S = route_rank(Wk,tk,Zjk,phi_jk);%推荐线路优先级排序 S = route_rank2(Wk,tk,Zjk,phi_jk,btw,t,headway);%推荐线路优先级排序 Temp_S=S; [btw,S,U,total_trip,total_traveltime,total_waitingtime,totoal_ridingtime,btw_vehicle,chengke] = vehicle_dispatch(btw,t_jk,S,U,Zjk,t,headway,total_trip,total_traveltime,total_waitingtime,totoal_ridingtime,btw_vehicle,chengke);%车辆分配 if isempty(S) s(plus_trip).route=Temp_S(:,1:3); pax_asg(plus_trip).record=Zjk; else index=find(Temp_S(:,1)==S(1,1)); s(plus_trip).route=Temp_S(1:index-1,:); unfinished_route=S(:,1); Zjk(:,unfinished_route)=0; pax_asg(plus_trip).record=Zjk; end S=[];%清空推荐线路 t=t+headway;%分配时间段后移一个batch btw_record(:,i+1)=btw; disp(['额外的运行周期:',num2str(plus_trip)]) end
最新发布
03-08
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值