C++数组

数组倒序

#include <iostream>
using namespace std;
#define  NUM 10
int a[NUM];
int main()
{
    for(int i = 0; i < NUM; ++i)
       cin >> a[i];
    for(int k = NUM - 1; k >= 0; --k)
       cout << a[k] << " "; //下标问题难掌握 
    return 0;
 } 

筛法求素数

#include <iostream>
using namespace std;
int main()
{
    int Max_Num;
    cin >> Max_Num;
    bool isPrime[Max_Num+10];
    for(int i = 2; i <= Max_Num; ++i)   
        isPrime[i] = true;
    for(int k = 2; k <= Max_Num; ++k)
       {
               if(isPrime[k])              //检验该数是否被筛过 
               for(int m = 2 * k; m <= Max_Num; m = m + k)   //不要用乘法,保持下标简洁 
                  isPrime[m] = false; 
       }
    int flag = 0;
    for(int i = 2; i <= Max_Num; ++i)       //i与前几次循环不同,逐一增加 
       {
           if(isPrime[i]) 
           {
               printf("%2d ", i);
               flag++;
               if(flag == 5) 
               {
                   flag = 0;
                   printf("\n");
               }
           }
       }
    return 0;
}

数组取代分支结构

#include <iostream>
#include <string.h>
using namespace std;
int main()
{
    string weekdays[] = {"Monday", "Tuesday", "Wednesday", "Thursday"
    ,"Friday", "Saturday", "Sunday"};
    int n;
    cin >> n;
    if((n > 0) && (n <= 7))
    cout << weekdays[n-1];
    else
    cout << "Illegal";
    return 0;
  }  

数组取代分支结构

#include <iostream>
#include <string.h>
using namespace std;
int main()
{
    string weekdays[] = {"Monday", "Tuesday", "Wednesday", "Thursday"
    ,"Friday", "Saturday", "Sunday"};
    int n;
    cin >> n;
    if((n > 0) && (n <= 7))
    cout << weekdays[n-1];
    else
    cout << "Illegal";
    return 0;
  }  

判断2012.1.22(星期天)后星期几

#include <iostream>
using namespace std;
int monthdays[13] = {-1,31,28,31,30,31,30,31,31,30,31,30,31};
//巧妙绕过monthdays[0],避免被下标弄晕
int main()
{
    int year, month, day;
    int d = 0;
    cin >> year >> month >> day;//2012.1.1(星期天) 
    for(int y = 2012; y < year; y++)
    {
        if((y % 4 == 0 && y % 100 != 0 )||(y % 400) == 0 )
           d += 366;
        else
           d += 365;

    }
    if((year % 4 == 0 && year % 100 != 0 )||(year % 400) == 0 )
        monthdays[2] = 29;
    for(int m = 1; m < month; m++)
    d += monthdays[m];
    d = d + day;
    d = d % 7;
    cout << d - 1<< endl; 
    return 0;
 } 

矩阵的乘法

#include <iostream>
using namespace std;
//开头定义好三个矩阵
#define ROWS 8
#define COLS 8
int a[ROWS][COLS];
int b[ROWS][COLS];
int c[ROWS][COLS];
int main()
{
     int i, j, k;
     int m, n;
     cin >> m >> n;

     for(i = 0; i < m; i++)
         for(j = 0; j < n; j++)
             cin >> a[i][j] ;
     int p, q;
     cin >> p >> q;

     for(i = 0; i < p; i++)
         for(j = 0; j < q; j++)
             cin >> b[i][j];

    int sum = 0;
    for(i = 0; i < m; i++)
    {
        for(j = 0; j < q; j++)
        {
            for(sum = 0, k = 0; k < n; k++)   //sum变量每次归0 
                sum += a[i][k] * b[k][j];
                c[i][j] = sum;
        }
    }                       //多层,套好括号 
    for(i = 0; i < m; i++)
    {
        for(j = 0; j < q; j++)
            {
                cout << c[i][j] << " "; 
            }
        cout << endl;
    }                           //括号的使用 
    return 0;                    
}
#许愿#
全部评论
日常许愿
1
送花
回复
分享
发布于 2019-12-06 08:46
点赞
送花
回复
分享
发布于 2019-12-05 12:58
滴滴
校招火热招聘中
官网直投

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务