天天看點

第18周報告1:指向字元的指針

任務:有一字元串,包含n個字元。實作函數,将此字元串中從第m個字元開始的全部字元複制成為另一個字元串,當m值大于str1的長度n時,輸出空字元串。

實驗目的:學會指針通路字元數組

實驗内容:從字元數組中取出指定位置開始的子符串

/* 程式頭部注釋開始
* 程式的版權和版本聲明部分
* Copyright (c) 2011, 煙台大學計算機學院學生
* All rights reserved.
* 檔案名稱:  substr.cpp                           
* 作    者:  賀利堅                           
* 完成日期:  2011 年 12 月 22 日
* 版 本 号:  v1.0       
* 對任務及求解方法的描述部分
* 輸入描述:字元串str1和開始位置m
* 問題描述:将字元串str1中從第m個字元開始的全部字元複制成為另一個字元串并輸出。
* 算法說明:若m大于str1的長度,傳回空串,否則,複制從m位置開始的直到結束的所有符号。
*/
#include <iostream>
using namespace std;
void fun(char*, char*, int);
int main()
{
  charstr1[100]="I am a student",str2[100];
  int m;
  cin>>m;
  fun(str1,str2,m);
  cout<<str2<<endl;
  return 0;
}
void fun(char *p1, char *p2,  int m)
{
   intn=strlen(p1);
   if(n<m)
    {
              cout<<"No trans\n";
              *p2='\0';   //此處必須有指派,否則不能稱為字元串,當然,空串也是串。
              return;
    }
   p1=p1+m-1;
   for(int i=m;i<n;i++)
          *p2++=*p1++;
   *p2='\0';    //複制完後,結尾應該指派'\0',作為字元串結束
   return;
}           

終于能在CSDN上再發博文了。接受了一次帳戶安全教育。

繼續閱讀