国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Visual C++利用多線程模擬并行計算

2019-11-17 05:30:32
字體:
來源:轉載
供稿:網友

  隨著信息時代的到來,需要處理的信息量越來越龐大,需要解決的問題越來越復雜,使得計算量劇增。通過提高單個處理器的計算速度和采用傳統的"順序(串行)"計算技術已難以勝任。因此,需要有功能更強大的計算機系統和計算機技術來支撐。并行計算機及并行計算技術應運而生。

  但由于缺乏實驗環境和機器設備,我們普通人很難研究并行算法,即使有了想法也同樣面臨著無法驗證的尷尬。不過,好在像面向對象語言c++,java等都提供了多線程,使我們可以模擬多臺處理機。下面,我就一個簡單的例子,向大家介紹一下在vc下如何利用多線程模擬多處理機并行求取最大值問題。

  題目如下:令n=2的m次方,A是一個2n維的數組,待求最大值的數存放在A(n),A(n+1),……A(2n-1)中,所求得的最大值置于A(1),于是算法描述如下:

  輸入:n=2的m次方個數存在數組A(n;2n-1)中;

  輸出:最大數置于A(1)中。

Begin
For k=m-1 to 0 do
For j=2 to 2n-1 par do
A(j)=max(A(2j),A(2j+1))
End For
End For
End

  顯然,算法的時間t(n)=O(lgn),總比較次數為O(n),而最大的處理器數p(n)=n/2。(也即最大的線程數。)

  首先,我們建立一個基于對話框的應用程序,然后放置如圖所示控件:
  Visual C++利用多線程模擬并行計算(圖一)

  然后定義全局變量如下,array用于存放產生的隨機數。
int g_nCount=0,j=0;
int *array;
  在對話框的初始化函數中,我們隨機產生n個數并存于數組array中,程序代碼如下:
void CDemoDlg::OnBTnInitial()
{
 // 初始化數組

 srand((unsigned)time(NULL));
 int i,temp;
 CString str;
 UpdateData(true);
 g_nCount=pow(2,m_intCount);
 array=new int[2*g_nCount];
 //根據用戶的輸入,產生2的m次方的隨機數并存于array[n]…a[2n-1]中
 for(i=g_nCount;i<2*g_nCount;i++)
 {

  temp=rand()/100;
  array[i]=temp;
 }
 //顯示產生的n個隨機數
 for(i=g_nCount;i<2*g_nCount;i++)
 {
  str.Format("Array[%d]= %d",i,array[i]);
  m_strArray+="/r/n";
  m_strArray+= str;
  m_strArray+="/r/n";
 }
 m_strArray+="/r/n";
 UpdateData(false);

}void CDemoDlg::OnBtnCompute()
{
 // 啟動線程進行計算
 int k;
 for(k=m_intCount-1;k>=0;k--)
 {
  for(j=pow(2,k);j<pow(2,K+1);J++)
  {
   AfxBeginThread(ComputeThread,GetSafeHwnd(),
   THREAD_PRIORITY_NORMAL);
  }

 }
 //線程體:較array[2j]與array[2j+1]的大小,將大值置于array[j]中
 UINT ComputeThread(LPVOID pParam)
 {
  if(array[2*j]>=array[2*j+1])
  {
   array[j]=array[2*j];
  }
  else
  {
   array[j]=array[2*j+1];
  }
  return 0;

 }
}
//顯示計算結果
void CDemoDlg::OnBtnShow()
{
 // TODO: Add your control notification handler code here
 int k;
 CString str;
 for(k=1;k<2*g_nCount;k++)
 {
  str.Format("Array[%d]= %d",k,array[k]);
  m_strArray+="/r/n";
  m_strArray+= str;
  m_strArray+="/r/n";
 } UpdateData(false);
}

重置功能的實現代碼,主要是將數組清空:
void CDemoDlg::OnBtnClear()
{
 // TODO: Add your control notification handler code here
 m_strArray.Empty ();
 m_ctrlCount.SetFocus();
 m_ctrlCount.Clear();
 m_ctrlCount.SetSel(1);

 UpdateData(false);

 g_nCount=0;
 j=0;}

  運行結果如圖:

  Visual C++利用多線程模擬并行計算(圖二)

  從運行的結果圖上我們可以清楚的看到線程的計算排序過程。

  此程序只是一個利用多線程進行并行計算的簡單例子,希望對各位進行并行算法的研究有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 金川县| 石阡县| 井冈山市| 象州县| 崇信县| 兰州市| 广河县| 上思县| 安仁县| 石楼县| 兖州市| 临桂县| 香河县| 崇州市| 桃园市| 承德县| 论坛| 通州区| 丹寨县| 普兰县| 光山县| 江口县| 安义县| 府谷县| 上林县| 华坪县| 清流县| 巧家县| 神木县| 梓潼县| 东港市| 虎林市| 九江市| 集安市| 杭州市| 黄冈市| 栖霞市| 盈江县| 肥乡县| 临朐县| 越西县|