UVA - 414 Machined Surfaces(题意不好懂)

懂了题意就是水题。

给你n行数每行都有25个字符,第一个和最后一个都是‘X‘,中间可能包含空格,问每次与左边(或者右边)移动,直到中间没有空格为止,问此时还有多少空格。

我们直接考虑移动完之后的状态,肯定是空格少的那一行最先移动完,那么只要统计出原先总的空格数减去空格最少的那一行乘×n就是目前剩下的字符了。

#include<cstdio>
#include<cstring>

int main()
{
    int n,i,j,m,sum,maxn;
    char s[30];
    while(~scanf("%d",&n),n)
    {
        sum=0;
        maxn=25;
        getchar();
        for(i=0;i<n;i++)
        {
            m=0;
            fgets(s,30,stdin);
            for(j=0;j<strlen(s);j++)
            {
                if(s[j]==' ') {m++;sum++;}
            }
            if(m<maxn) maxn=m;
        }
        printf("%d\n",sum-maxn*n);
    }
    return 0;
}


郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。