青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 183,  comments - 10,  trackbacks - 0

統一的考勤處理程序

總共分為 6 個處理步驟,如下:
0. 進行考勤數據的預處理,其中有篩選打卡成功的記錄,并對成功的記錄進行排序。這一步比較靈活,根據不同的考勤數據做不同的預處理以得到后續可以處理的數據。
1. 針對打卡成功的考勤記錄,找出每天的最早時間和最晚時間。
2. 根據最早時間和最晚時間得到遲到和早退記錄。
3. 由于可能存在缺勤的情況,所以需要在制定工作日內找到未存在考勤記錄的記錄,作為缺勤記錄。
4. 將前面的遲到和早退記錄與缺勤記錄進行整合。
5. 根據整合的結果輸出考勤異常的記錄。輸出有多種形式,前面的遲到、早退、缺勤等數據一定了,這里的輸出格式可以按照:按人名-行輸出、按人名-列輸出、按日期-行輸出、按日期-列輸出、人名-日期輸出、日期-人名輸出等多種方式。

具體的程序實現如下:
0.
#include <iostream>
#include <fstream>
#include <sstream>
#include <string>
#include <vector>
#include <algorithm>
using namespace std;

int main()
{
 ifstream fin_kaoqin("kaoqin.txt");
 ofstream fout_0("0.txt");
 if (!fin_kaoqin || !fout_0)
 {
  cerr << "File error!" << endl;
  system("PAUSE");
  exit(1);
 }
 vector<string> checkins;
 string name, date, time;
 string s1, s2, s3, ind;
 string line;
 while (getline(fin_kaoqin, line))
 {
  istringstream sin(line);
  sin >> s1 >> s2 >> name >> date >> time >> s3 >> ind;
  if (ind != "成功")
  {
   continue;
  }
  checkins.push_back(name + '\t' + date + '\t' + time);
 }
 sort(checkins.begin(), checkins.end());
 for (vector<string>::size_type i = 0; i != checkins.size(); ++i)
 {
  fout_0 << checkins[i] << endl;
 }
 fin_kaoqin.close();
 fout_0.close();
 return 0;
}

1.
#include <iostream>
#include <fstream>
#include <sstream>
#include <map>
#include <set>
#include <vector>
#include <string>
using namespace std;

int main()
{
 ifstream fin("0.txt");
 ofstream fout("1.txt");
 ofstream fout_names("names.txt");
 ofstream fout_dates("dates.txt");
 if (!fin || !fout || !fout_names || !fout_dates)
 {
  cerr << "File error!" << endl;
  system("PAUSE");
  exit(1);
 }
 map<string, vector<string> > checkins;
 set<string> names, dates;
 string line;
 string name, date, time;
 while (getline(fin, line))
 {
  istringstream sin(line);
  sin >> name >> date >> time;
  names.insert(name);
  dates.insert(date);
  checkins[name + '\t' + date].push_back(time);
 }
 string earliest, lastest;
 for (map<string, vector<string> >::const_iterator cit = checkins.begin(); cit != checkins.end(); ++cit)
 {
  earliest = lastest = cit->second[0];
  for (vector<string>::size_type i = 0; i != cit->second.size(); ++i)
  {
   if (earliest > cit->second[i])
   {
    earliest = cit->second[i];
   }
   else if (lastest < cit->second[i])
   {
    lastest = cit->second[i];
   }
  }
  fout << cit->first << '\t' << earliest << endl;
  fout << cit->first << '\t' << lastest  << endl;
 }
 for (set<string>::const_iterator cit = names.begin(); cit != names.end(); ++cit)
 {
  fout_names << *cit << endl;
 }
 for (set<string>::const_iterator cit = dates.begin(); cit != dates.end(); ++cit)
 {
  fout_dates << *cit << endl;
 }
 fin.close();
 fout.close();
 fout_names.close();
 fout_dates.close();
 return 0;
}

2.
#include <iostream>
#include <fstream>
#include <sstream>
#include <string>
using namespace std;

struct checkin
{
 string name;
 string date;
 string time;
};

void foo(ofstream& fout_nor, ofstream& fout_abn, const checkin& ci1, const checkin& ci2, const string& start, const string& end)
{
 if (ci1.time <= start)
 {
  fout_nor << ci1.name << '\t' << ci1.date << '\t' << ci1.time << endl;
 }
 else
 {
  fout_abn << ci1.name << '\t' << ci1.date << '\t' << ci1.time << "遲到" << endl;
 }
 if (ci2.time >= end)
 {
  fout_nor << ci2.name << '\t' << ci2.date << '\t' << ci2.time << endl;
 }
 else
 {
  fout_abn << ci2.name << '\t' << ci2.date << '\t' << ci2.time << "早退" << endl;
 }
}

int main()
{
 ifstream fin("1.txt");
 ofstream fout_nor("2-normal.txt"), fout_abn("2-abnormal.txt");
 if (!fin || !fout_nor || !fout_abn)
 {
  cerr << "File error!" << endl;
  system("PAUSE");
  exit(1);
 }
 string line1, line2;
 checkin ci1, ci2;
 string start = "083000", end = "173000";
 while (getline(fin, line1) && getline(fin, line2))
 {
  istringstream sin1(line1), sin2(line2);
  sin1 >> ci1.name >> ci1.date >> ci1.time;
  sin2 >> ci2.name >> ci2.date >> ci2.time;
  foo(fout_nor, fout_abn, ci1, ci2, start, end);
 }
 fin.close();
 fout_nor.close();
 fout_abn.close();
 return 0;
}

3.
#include <iostream>
#include <fstream>
#include <sstream>
#include <string>
#include <map>
#include <set>
#include <vector>
using namespace std;

int main()
{
 ifstream fin_ci("0.txt");
 ifstream fin_name("names-filter.txt");
 ifstream fin_date("dates-filter.txt");
 ofstream fout_nowork("2.1-nowork.txt");
 if (!fin_ci || !fin_name || !fin_date || !fout_nowork)
 {
  cerr << "File error!" << endl;
  system("PAUSE");
  exit(1);
 }
 map<string, set<string> > name_date;
 string line, name, date;
 while (getline(fin_ci, line))
 {
  istringstream sin(line);
  sin >> name >> date;
  name_date[name].insert(date);
 }
 vector<string> names;
 while (fin_name >> line)
 {
  names.push_back(line);
 }
 vector<string> dates;
 while (fin_date >> line)
 {
  dates.push_back(line);
 }
 for (vector<string>::size_type i = 0; i != names.size(); ++i)
 {
  for (vector<string>::size_type j = 0; j != dates.size(); ++j)
  {
   if (name_date[names[i]].find(dates[j]) == name_date[names[i]].end())
   {
    fout_nowork << names[i] << '\t' << dates[j] << '\t' << "無出勤記錄!" << endl;
   }
  }
 }
 fin_ci.close();
 fin_name.close();
 fin_date.close();
 fout_nowork.close();
 return 0;
}

4.
#include <iostream>
#include <fstream>
#include <sstream>
#include <string>
#include <vector>
#include <algorithm>
using namespace std;

int main()
{
 ifstream fin_abnormal("2-abnormal.txt");
 ifstream fin_nowork("2.1-nowork.txt");
 ofstream fout_excep("2.2-exception.txt");
 if (!fin_abnormal || !fin_nowork || !fout_excep)
 {
  cerr << "File error!" << endl;
  system("PAUSE");
  exit(1);
 }
 vector<string> checkins;
 string line;
 while (getline(fin_abnormal, line))
 {
  checkins.push_back(line);
 }
 while (getline(fin_nowork, line))
 {
  checkins.push_back(line);
 }
 sort(checkins.begin(), checkins.end());
 for (vector<string>::size_type i = 0; i != checkins.size(); ++i)
 {
  fout_excep << checkins[i] << endl;
 }
 fin_abnormal.close();
 fin_nowork.close();
 fout_excep.close();
 return 0;
}

5.
#include <iostream>
#include <fstream>
#include <sstream>
#include <string>
#include <map>
#include <set>
#include <vector>
using namespace std;

struct date_time
{
 string date;
 string time;
};

int main()
{
 ifstream fin_ci("2.2-exception.txt");
 ifstream fin_names("names-filter.txt");
 ifstream fin_dates("dates-filter.txt");
 ofstream fout_row("3-name-row-filter.txt");
 ofstream fout_col("3-name-column-filter.txt");
 if (!fin_ci || !fout_row || !fout_col || !fin_names || !fin_dates)
 {
  cerr << "File error!" << endl;
  system("PAUSE");
  exit(1);
 }
 map<string, vector<date_time> > bypers;
 vector<string> names;
 string line, name;
 date_time dt;
 int MAXNUM = 0;
 // 讀取想要的人名
 set<string> names_filter;
 while (fin_names >> name)
 {
  names_filter.insert(name);
 }
 // 讀取想要的日期
 set<string> dates_filter;
 while (fin_dates >> line)
 {
  dates_filter.insert(line);
 }
 while (getline(fin_ci, line))
 {
  istringstream sin(line);
  sin >> name >> dt.date >> dt.time;
  // 提取想要的人名和日期
  if (names_filter.find(name) == names_filter.end() || dates_filter.find(dt.date) == dates_filter.end())
  {
   continue;
  }
  bypers[name].push_back(dt);
 }
 // 同名字下相同日期的合并
 for (map<string, vector<date_time> >::iterator cit = bypers.begin(); cit != bypers.end(); ++cit)
 {
  // 提取名字
  names.push_back(cit->first);
  
  vector<date_time> tmp, hold = cit->second;
  vector<date_time>::size_type i = 0;
  while (i < hold.size() - 1)
  {
   if (hold[i].date == hold[i+1].date)
   {
    dt.date = hold[i].date;
    dt.time = hold[i].time + hold[i + 1].time;
    tmp.push_back(dt);
    i += 2;
   }
   else
   {
    dt.date = hold[i].date;
    dt.time = hold[i].time;
    tmp.push_back(dt);
    ++i;
   }
  }
  // 最后兩個如果相等,那么 i 一下子回跳到 hold.size()。
  // 如果不相等,那么 i 變成 hold.size() - 1, 推出循環。
  // 也就是說推出循環有兩種情況,分別是 i 為 hold.size() 和 hold.size() - 1
  // i 為 hold.size() 的情況沒有遺漏記錄,i 為 hold.size() - 1 遺漏了數據,所以在此補充。
  if (i == hold.size() - 1)
  {
   dt.date = hold[i].date;
   dt.time = hold[i].time;
   tmp.push_back(dt);
   ++i;
  }
  // 記錄最大記錄個數
  if (MAXNUM < tmp.size())
  {
   MAXNUM = tmp.size();
  }
  cit->second = tmp;
 }
 // 按行輸出
 for (map<string, vector<date_time> >::const_iterator cit = bypers.begin(); cit != bypers.end(); ++cit)
 {
  fout_row << cit->first << '\t';
  for (vector<date_time>::size_type i = 0; i != cit->second.size(); ++i)
  {
   fout_row << cit->second[i].date << '\t' << cit->second[i].time << '\t';
  }
  fout_row << endl;
 }
 
 // 先輸出人名
 for (vector<string>::size_type i = 0; i != names.size(); ++i)
 {
  fout_col << names[i] << '\t';
 }
 fout_col << endl;
 // 按列輸出
 for (int i = 0; i != MAXNUM; ++i)
 {
  for (vector<string>::size_type j = 0; j != names.size(); ++j)
  {
   if (bypers[names[j]].size() > i)
   {
    fout_col << bypers[names[j]][i].date << ',' << bypers[names[j]][i].time << '\t';
   }
   else
   {
    fout_col /* << "XXXXXX" */ << '\t';
    // 這里的輸出 "XXXXXX" 可以省略,即可以直接 fout_col << '\t';
   }
  }
  fout_col << endl;
 }
 fin_ci.close();
 fout_row.close();
 fout_col.close();
 return 0;
}

posted on 2012-10-29 17:04 unixfy 閱讀(177) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲婷婷免费| 欧美一区二区三区四区在线观看| 久久综合久久综合久久综合| 午夜精品久久久久久99热软件| 国产精品乱码一区二区三区 | 欧美制服丝袜第一页| 国产精品三级视频| 久久爱www久久做| 欧美在线观看一二区| 在线免费观看一区二区三区| 欧美大片网址| 欧美日韩在线免费视频| 羞羞色国产精品| 欧美综合二区| 亚洲精品国偷自产在线99热| 国产午夜精品一区理论片飘花| 久久国产欧美| 美女黄网久久| 一区二区三区欧美日韩| 亚洲综合国产| 亚洲第一区在线| a4yy欧美一区二区三区| 国产一区二区三区四区在线观看| 另类亚洲自拍| 欧美日韩一区二区三区在线观看免| 亚洲影院色无极综合| 久久精品在线免费观看| 一本色道久久综合亚洲精品不卡 | 久久人人爽爽爽人久久久| 久久精品99国产精品| 99精品99久久久久久宅男| 午夜在线一区二区| 亚洲三级免费电影| 亚洲自拍偷拍福利| 亚洲精品一区二区三区蜜桃久| 一区二区久久| 亚洲国产视频直播| 午夜激情久久久| 一区二区三区日韩精品| 久久久女女女女999久久| 亚洲一区国产| 欧美激情一区二区三区全黄| 久久久999国产| 国产精品99一区二区| 欧美xxx成人| 国产午夜精品理论片a级大结局 | 亚洲嫩草精品久久| 亚洲激情一区二区| 久久国产精品久久久久久| 亚洲一区二区高清| 欧美国产日韩在线观看| 蜜臀va亚洲va欧美va天堂| 国产精品日本欧美一区二区三区| 能在线观看的日韩av| 国产综合色在线| 亚洲欧美日本视频在线观看| 亚洲视频久久| 欧美极品在线观看| 亚洲国产精品第一区二区三区| 国产精品色一区二区三区| 99亚洲一区二区| 亚洲乱码国产乱码精品精天堂| 久久精品视频一| 麻豆国产精品777777在线 | 欧美成人一区在线| 免费成人你懂的| 一色屋精品亚洲香蕉网站| 欧美一区二区三区的| 久久精品成人| 国内精品嫩模av私拍在线观看| 亚洲一区二区三区在线看| 亚洲男人的天堂在线| 国产精品丝袜白浆摸在线| 99re6热只有精品免费观看| 一区二区av在线| 欧美日韩国产首页在线观看| 亚洲美女黄网| 亚洲免费视频在线观看| 国产精品福利在线观看| 亚洲欧美日韩第一区| 久久性天堂网| 亚洲国产免费| 欧美另类在线观看| 国产精品99久久不卡二区| 欧美一站二站| 一区在线影院| 欧美国产在线观看| 亚洲视频一区二区在线观看| 欧美一区二区高清| 在线不卡欧美| 欧美日产一区二区三区在线观看| 洋洋av久久久久久久一区| 欧美在线播放一区| 亚洲电影在线观看| 欧美日韩综合精品| 午夜国产精品视频免费体验区| 久久婷婷人人澡人人喊人人爽| 亚洲国产精品专区久久| 欧美日韩一区不卡| 亚洲一区国产精品| 欧美大片免费观看| 亚洲欧美国产77777| 狠狠干狠狠久久| 欧美日韩国产色站一区二区三区 | 久久在线视频| 一区二区精品| 狠狠色狠狠色综合日日小说| 欧美激情aaaa| 亚洲欧美日产图| 亚洲区一区二| 久久婷婷影院| 亚洲欧美日韩一区在线| 亚洲高清在线精品| 国产日韩精品视频一区| 欧美国产精品一区| 欧美在线免费视频| aa国产精品| 亚洲高清一二三区| 久久久精品视频成人| 中文精品视频| 亚洲国产日韩欧美综合久久| 国产日韩欧美综合一区| 欧美日韩一级黄| 欧美成年视频| 久久综合狠狠| 久久成人精品视频| 亚洲少妇诱惑| 99国产精品99久久久久久| 牛牛精品成人免费视频| 久久国产视频网| 午夜精品亚洲| 亚洲一区二区欧美日韩| 99精品国产高清一区二区| 亚洲电影免费观看高清完整版在线| 国产欧美三级| 国产老肥熟一区二区三区| 欧美午夜在线观看| 欧美人与禽猛交乱配视频| 欧美韩国日本一区| 欧美福利视频网站| 免费成人毛片| 免费日韩精品中文字幕视频在线| 欧美专区日韩专区| 欧美一区二区三区四区在线观看| 亚洲婷婷综合久久一本伊一区| 一区二区三区欧美日韩| 一区二区三区视频在线观看| 一本久道久久久| 一本久久综合亚洲鲁鲁| 99人久久精品视频最新地址| 亚洲毛片网站| 亚洲一区影院| 欧美在线看片| 久久久夜夜夜| 欧美电影资源| 欧美日一区二区在线观看| 欧美视频在线看| 国产精品日韩精品| 国产日韩一区在线| 激情亚洲一区二区三区四区| 伊人夜夜躁av伊人久久| 亚洲第一毛片| 一区二区三区免费在线观看| 亚洲欧美综合| 久久影院亚洲| 亚洲国产精品va在线看黑人动漫| 亚洲国产一区二区三区在线播| 亚洲激情一区| 亚洲一区二区在线视频| 久久久www成人免费毛片麻豆| 久久免费高清视频| 欧美人成网站| 国产性色一区二区| 亚洲国产小视频| 亚洲在线电影| 免费人成网站在线观看欧美高清| 亚洲福利在线观看| 亚洲一卡久久| 久久综合九色九九| 国产精品国色综合久久| 伊人春色精品| 亚洲免费视频成人| 欧美电影资源| 亚洲综合欧美日韩| 免费成人小视频| 国产视频一区在线| av成人黄色| 麻豆成人91精品二区三区| 99在线精品视频在线观看| 久久精品国产69国产精品亚洲 | 欧美超级免费视 在线| 国产精品一级久久久| 亚洲精品一区二区三区99| 久久成人国产| 亚洲美女av网站| 免费日韩视频| 激情欧美国产欧美| 午夜视频久久久| 亚洲精品在线看| 久久免费国产|