• 竞赛入门 数组和字符串


    读入一些整数,逆序输出 :

    #include <iostream>

    using namespace std;

    int main()

    {

      const int MAX = 100;

    int arr[MAX];

    int temp,index=0;

    while(cin>>temp,temp!=0)

    arr[index++]=temp;

    while(index>0)

    cout<<arr[--index]<<" ";

    return 0 ;

    }

    n盏灯,编号1-n,第1个人把所有的灯打开,第二个按下所有编号为2的倍数的开关,第3个人按下第三倍数的开关,以此类推,一共有k个人,问最后有哪些灯开着?
    输入n和k,输出开着的灯编号.
    输入: 7 3
    输出:1 5 6 7
     
    #include <iostream>
    using namespace std;
    int main()
    {
        int n=0,k=0;//初始化n为灯 k为人的个数
    cin>>n>>k;
    int lamp[100];
    for(int i = 0;i!=n;++i){
    lamp[i]=0;
    }
    for(int i = 1;i<=k;++i)
    {
    for(int j = 1;j <= n/i;++j)
    {
    lamp[i*j-1]=!lamp[i*j-1];
    }
    }
    for(int i = 0;i!=n;++i)
    if(lamp[i]!=0)
    cout<<i+1<<" ";
    return 0 ;
    return 0 ;
    }
     
     
    红色循环部分.改成  
    for(int j=1;j<=n;++j)
    {
        if(j%i==0)
        lamp[j-1]=!  lamp[j-1];
    }
    这样感觉效果更好.
     
     
     
    蛇形填数
    在n*n方阵里填入 1,2,...,n*n,要求填成蛇形。例如n=4时方阵为:
    10 11  12  1
    9   16  13  2
    8   15  14  3
    7    6   5    4
     
    上面的方阵,多余的空格只是为了便于观察规律,不比严格输出.n<=8;
     
     
    #include <iostream>
    using namespace std;
    int main()
    {
        const int MAX =10;
    int snake[MAX][MAX];
     
    for(int i =0;i!=MAX;++i){
    for(int j =0;j!=MAX;++j)
    snake[i][j]=0;
    }
     
    int n,x,y;
    cin>>n;
    x=0;y= n-1;
    int curNum= snake[x][y]=1;
    while(curNum<n*n)
    {
    while(x+1<n&&snake[x+1][y]==0)
    {
    snake[++x][y]=++curNum;
    }
    while(y-1>=0&&snake[x][y-1]==0)
    {
    snake[x][--y]=++curNum;
    }
    while(x-1>=0&&snake[x-1][y]==0)
    {
    snake[--x][y]=++curNum;
    }
    while(y+1<n&&snake[x][y+1]==0)
    {
    snake[x][++y]=++curNum;
    }
     
    }
        cout<<"最后curNum:"<<curNum<<endl;
        cout<<"n*n:"<<n*n<<endl;
    for(int i =0;i<n;i++)
    {
    for(int j = 0;j<n;j++)
    cout<<snake[i][j]<<endl;
    }
     
    return 0 ;
    }
     
     
    最长回文子串:
    输入一个字符串,求出其中最长的回文子串。子串:在原串中连续出现的字符串片段。判断是,应该忽略所有标点符号和空格,切忽略大小写,但输出应该保持原样。
     
     
    #include "stdafx.h"
    #include<iostream>
    #include<string>
    using namespace std;
     
    int _tmain(int argc, _TCHAR* argv[])
    {  
    string test="youxixuoy you a re pig";
    string s="";
    int maxlen=0;
    int locate[100];
    int left=0,right=0;
     
    for(string::size_type i = 0;i<=test.size();++i)
    {
    if(isalpha(test[i])){
    s+=toupper(test[i]);
    locate[s.size()-1]=i;
    }
    }
    for(string::size_type i =0;i<=s.size();++i)
    {
    for(string::size_type j = i+1;j<=s.size();++j)
    {
    string word(s.begin()+i,s.begin()+j);
    bool ok=true;
    for(string::size_type m=0;m<=word.size()/2;++m)
    {
    if(word[m]!=word[word.size()-1-m])
    ok = false;
    }
    if (ok)
    {
    if(word.size()>maxlen)
    {
    left = i;right =j;
    maxlen=word.size();
    }
    }
    }
    }
    for(int i = locate[left];i<=locate[right-1];i++)
    cout<<test[i];
    return 0 ;
    }
  • 相关阅读:
    应用Solaris11放置光盘修复solaris引导妨碍
    HP 3803TX 装置debian4 Linux
    释放linux细碎的内存
    linux批量查找文件内容
    Oracle 10g R2 for Solaris x86在Solaris 11上的装配
    Linux 零碎进修之shell剧本进修
    华硕易PC台式机版7月环球上市 或运转Linux
    Linux文件琐细 一分钱一分货
    linux下平安管理
    预装Windows或Ubuntu,戴尔出Mini Inspiron 8.9寸笔记本
  • 原文地址:https://www.cnblogs.com/crazycodehzp/p/3349066.html
Copyright © 2020-2023  润新知