亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? weather.bak

?? This Project gives a complete idea for user to learn how to create live project with a specific user
?? BAK
字號:
//Weather Temperature Recording Project
//Programmed by : Vivek Patel


//For bugs plz. contact me ---->
//Email : vivek_patel9@rediffmail.com
//Website : www.vivekpatel.cjb.net


//Some facts about project
//->It stores a data file in c:\ (user can change it's to form relative but for sake of simplicity i have taken absolute path).
//->This project is strickly for novice to get familiar with file concepts.
//->Still it find difficulty than feel free to contact me.


#include <iostream.h>
#include <fstream.h>
#include <iomanip.h>
#include <math.h>
#include <conio.h>
#include <string.h>


fstream file;
char year[5]="";

//Non-Member function to find month, to avoid user data-entry
char *returnMonth(int m){
	switch(m){
		case 1 : return("January");
		case 2 : return("February");
		case 3 : return("March");
		case 4 : return("April");
		case 5 : return("May");
		case 6 : return("June");
		case 7 : return("July");
		case 8 : return("August");
		case 9 : return("September");
		case 10 : return("October");
		case 11 : return("November");
		case 12 : return("December");
	}
	return("Invalid");
}

//Non-Member functions, checks for whether file is loaded or not
//it returns 1 if not loaded and 0 otherwise.
int checkFile(){
	if(file==NULL){
	   cout<<"\nThere is No Data to Display\n";
	   getch();
	   return(1);
	}
	return(0);
}

class weather
{
     public:
     double avgtemp[12];
     char month[12][20];
     weather();
     void getdata(int m){ //simple getdata...
	 strcpy(month[m],returnMonth(m)); //avoiding user to input
	 cout<<"\nEnter temperature for "<<month[m]<<" : ?\b";
	 cin>>avgtemp[m];
     }
     void displaydata(int m){ //simple displaydata
	 cout<<setw(20)<<setprecision(2)<<setiosflags(ios::left)
	     <<setiosflags(ios::showpoint)
	     <<month[m]<<setw(10)<<setiosflags(ios::right)<<avgtemp[m];
     }
     void displaytemp(int i){ //Display only Temperature data
	  cout<<setw(10)<<setprecision(2)<<setiosflags(ios::right)
	      <<setiosflags(ios::showpoint)<<avgtemp[i];
     }
     double returntemp(int i){
	  return(avgtemp[i]);
     }
     void loadfile();
     void displaytempscale(); //for displaying temperature scale
     void updatedata(int m,double t)
     {
	strcpy(month[m],returnMonth(m));
	avgtemp[m]=t;
     }
     int validate(double t){ //Validate entered temperature (change to suit ur requirement).
	if(t>55 || t < (-20))
	   return(1); //states that invalid entry
	else
	   return(0); //valid entry
     }
};

weather :: weather(){  //Constructor to intialize object
	for(int i=0;i<12;i++)
	{
		avgtemp[i]=0;
		month[i][0]=NULL;
	}
}

void weather :: loadfile(){  //for Selecting Year or creation of new year file.
	clrscr();
	file.close(); //It is required when trying to open different year files,
		     //while there is already loaded any year file.
	char filename[20]="";
	cout<<"\n*****Select a Year to Work With*****\n\n";
	cout<<"Enter Year (eg: 2001)  : ?\b";
	cin>>year;
	strcat(filename,"c:\\"); //Here i am assuming that path must be c:\
	strcat(filename,"data"); //if u wan't to skip that criteria just remove this lines.
	strcat(filename,year);
	strcat(filename,".dat");
	file.open(filename,ios::ate|ios::nocreate|ios::in|ios::out|ios::binary);
	if(file==NULL){
		char ans;
		cout<<"\nFile Dose Not Exist\n"
		    <<"Do you wan't to create it! (y or n) N : ?\b"; //By default No
		ans=getche();
		if(ans=='y'|| ans=='Y'){
		   file.open(filename,ios::ate|ios::in|ios::out|ios::binary);
		   cout<<"\n\nFile Created Successfully";
		}
		else{
		   file;
		   cout<<"\n\nFail to load data file";
		}
	}
       else if(file!=NULL){
		cout<<"\nData File is successfully loaded";
       }
       getch();
}

void weather :: displaytempscale(){
	int i,c=0;
	cout<<"\n\n";
	for(i=1;i<=70;i++)
	{
	   if(i<=10)
	      cout<<"0";
	   else if(i<=20)
	      cout<<"1";
	   else if(i<=30)
	      cout<<"2";
	   else if(i<=40)
	      cout<<"3";
	   else if(i<=50)
	      cout<<"4";
	   else if(i<=60)
	      cout<<"5";
	   else if(i<=70)
	      cout<<"7";
	}
	cout<<"\n";
	for(i=1;i<=7;i++)
	{
	  for(c=0;c<10;c++)
	    cout<<c;
	}
	cout<<"\n";
}

void intro()
{
	clrscr();
	cout<<"\n\n\n\n\n\n\n\n\t\t\t";
	cout<<"Programmed By : Vivek Patel\n"
	    <<"\t\t\tEmail : vivek_patel9@rediffmail.com\n"
	    <<"\t\t\tWebsite : www.vivekpatel.cjb.net";
	cout<<"\n\n\t\t\t";
	cout<<"Thanks for using this software.";
	getch();
}


void main(){
	char choice='1';
	int cnt,i,j,iNum,totstars=0,location,m;
	double decNum,dNum,high=0,low=99999,avg=0,t;
	char c;
	weather obj;
	file.close();
	do{
		clrscr();
		cout<<"\n*****Main Menu*****\n";
		cout<<"1>  Select a year to work with\n"
		    <<"2>  Display data as Table\n"
		    <<"3>  Display data as horizontal histogram\n"
		    <<"4>  Display Yearly Statistics to date\n"
		    <<"5>  Record Data\n"
		    <<"6>  Change Data\n"
		    <<"7>  Save Data\n"
		    <<"0>  Exit\n"
		    <<"Please enter a number (0...7) => ";
		choice=getche();
		//again for sake of simplicity i have directly return code
		//in case brace rather than going for member-function.
		switch(choice){
			case '0' :  intro();
				    goto out;
			case '1' :  obj.loadfile();
				    break;
			case '2' :  clrscr();
				    cout<<"\n*****Display Data as a Table*****\n\n";
				    if(checkFile()){
				       goto endtable;
				     }
				    cout<<"\nTable of Temperature data for "<<year;
				    cout<<"\n\n";
				    file.seekg(0,ios::end);
				    cnt=file.tellg();
				    cnt=cnt/sizeof(obj); //cnt contains how many records previously recorded
				    file.seekg(0,ios::beg);
				    for(i=1;i<=cnt;i++)
				    {
				       if(i==1)
					    cout<<"\nQuater 1 : ";
				       else if(i==4)
					    cout<<"\nQuater 2 : ";
				       else if(i==7)
					    cout<<"\nQuater 3 : ";
				       else if(i==10)
					    cout<<"\nQuater 4 : ";
				       file.read((char *)&obj, sizeof(obj));
				       if(!file.eof()){
					       obj.displaytemp(i);
					}
					file.clear();
				    }
				    getch();
				    endtable:
				    break;
			case '3' :  clrscr();
				    cout<<"\n*****Display Data as a Horizontal Histogram*****\n\n";
				    if(checkFile()){
				       goto endhistogram;
				    }
				    cout<<"Histogram of Temperature data for "<<year;
				    obj.displaytempscale();
				    file.seekg(0,ios::end);
				    cnt=file.tellg();
				    cnt=cnt/sizeof(obj); //cnt contains how many records previously recorded
				    file.seekg(0,ios::beg);
				    for(i=1;i<=cnt;i++)
				    {
				       cout<<"\n"<<setw(15)<<setiosflags(ios::left)<<returnMonth(i);
				       file.read((char *)&obj, sizeof(obj));
				       if(!file.eof()){
					     decNum=obj.returntemp(i);
					     iNum=floor(decNum);
					     dNum=decNum-iNum; //for finding decimal part.
					     totstars=iNum;
					     if(dNum >= 0.5)
						totstars++;
					     for(j=1;j<=totstars;j++)
						cout<<"*";
					     cout<<"  "<<totstars;
					}
					file.clear();
				    }
				    obj.displaytempscale();
				    getch();
				    endhistogram:
				    break;
			case '4' :  clrscr();
				    cout<<"\n*****Display Yearly Statistics to Date*****\n\n";
				    if(checkFile()){
				       goto endstatus;
				    }
				    cout<<"Temperature Statistics data for "<<year;
				    cnt=file.tellg();
				    cnt=cnt/sizeof(obj); //cnt contains how many records previously recorded
				    file.seekg(0,ios::beg);
				    high=avg=0;
				    low=99999;
				    for(i=1;i<=cnt;i++)
				    {
				       file.read((char *)&obj, sizeof(obj));
				       double tmp=obj.returntemp(i);
				       if(!file.eof()){
					     if(high < tmp)
						high=tmp;
					     if(low > tmp)
						low=tmp;
					     avg=avg+tmp;
					}
					file.clear();
				    }
				    avg=avg/double(cnt);
				    cout<<"\n\nHighest Monthly Average : "<<high;
				    cout<<"\nLowest Monthly Average : "<<low;
				    cout<<"\nAverage Yearly Temperature : "<<avg;
				    getch();
				    endstatus:
				    break;
			case '5' :      clrscr();
					cout<<"\n*****Record Data*****\n\n";
					if(checkFile()){
						goto endRecord;
					    }
					else{
					cnt=file.tellg();
					cnt=cnt/sizeof(obj); //cnt contains how many records previously recorded
					if(cnt==12)
					    cout<<"\n\nData-Entry of "<<year<<" is already been done\n";
					for(i=cnt+1;i<=12;i++)
					{
						enteragain:
						cout<<"\nDo u wan't to enter data for "<<returnMonth(i)<<" (Y or N) Y : ?\b";
						c=getche();
						if(c=='n' || c=='N')
						   goto endRecord;
						obj.getdata(i);
						if(obj.validate(obj.returntemp(i)))
						{
						    cout<<"\nInvalid Data Entry\n";
						    goto enteragain;
						}
						cin.get(c);
						file.write((char *) &obj, sizeof(obj));
					}
				     }
				     getch();
				     endRecord:
				      break;
			case '6' :  clrscr();
				    cout<<"\n*****Change Data*****\n\n";
				    if(checkFile()){
				       goto endchange;
				    }
				    else{
					cnt=file.tellg();
					cnt=cnt/sizeof(obj); //cnt contains how many records previously recorded
					tryagain:
					cout<<"\nEnter Month (in digit) whose temperature is to be changed : ?\b";
					cin>>m;
					if(m <= 0 || m > cnt){
					    cout<<"\n\nInvalid Month\n";
					    getch();
					    goto tryagain;
					}
					tempagain:
					cout<<"\nEnter Temperature : ?\b";
					cin>>t;
					if(obj.validate(t))
					 {
					     cout<<"\nInvalid Data Entry\n";
					     goto tempagain;
					 }
					file.seekg(0,ios::beg);
					location= (m-1) * sizeof(obj);
					file.seekp(location);
					obj.updatedata(m,t);
					 cin.get(c);
					file.write((char *) &obj, sizeof(obj))<<flush;
				     }
				     endchange:
				     break;
			case '7' : clrscr();
				   cout<<"\n*****Store the Current Data*****\n\n";
				   if(checkFile()){
					goto endsave;
				    }
				   flush(file);
				   cout<<"\nData in Memory is Saved successfully\n";
				   getch();
				   endsave:
				   break;
			default  : cout<<"\n\nInvalid Input\n";
				   getch();
		}
	}while(choice!='0');
flush(file);
file.close();
clrscr();
out:
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美日韩中文字幕一区二区三区 | 久久se精品一区精品二区| 欧美图区在线视频| 亚洲香肠在线观看| 欧美日韩成人一区二区| 五月婷婷综合激情| 欧美一区二区精品| 狠狠色伊人亚洲综合成人| 国产日韩欧美一区二区三区乱码 | 在线一区二区三区| 亚洲成人午夜影院| 欧美一区二区精美| 国产黄色精品视频| 亚洲天堂福利av| 欧美日韩成人激情| 久草热8精品视频在线观看| 久久久美女毛片| 成人高清在线视频| 亚洲国产欧美在线| 欧美电视剧在线看免费| 成人av在线影院| 亚洲成人一区二区在线观看| 欧美va亚洲va在线观看蝴蝶网| 国产精品白丝jk黑袜喷水| 日韩理论电影院| 69av一区二区三区| 免费看日韩a级影片| 欧美精品一区二区久久久| 欧美在线免费播放| 麻豆精品一区二区三区| 亚洲网友自拍偷拍| 欧美一区二区成人6969| 懂色中文一区二区在线播放| 亚洲成人自拍一区| 国产丝袜欧美中文另类| 欧美日韩一区二区三区不卡| 国产美女精品人人做人人爽 | av亚洲精华国产精华| 亚洲123区在线观看| 国产欧美日产一区| 日韩一区二区在线观看| 91在线云播放| 国精品**一区二区三区在线蜜桃| 亚洲乱码国产乱码精品精可以看| 精品精品欲导航| 欧美综合欧美视频| 风间由美一区二区三区在线观看 | 欧美一级生活片| 91亚洲永久精品| 国产老肥熟一区二区三区| 亚洲第一激情av| 中文字幕色av一区二区三区| 精品少妇一区二区三区日产乱码| 色94色欧美sute亚洲线路一ni | 久久色.com| 欧美日本一区二区三区四区| av在线不卡电影| 国产精品一区二区在线播放 | 久久99精品一区二区三区三区| 一区二区国产视频| 国产精品嫩草影院com| 欧美精品一区二区在线播放| 亚洲视频 欧洲视频| 亚洲精品一区二区在线观看| 欧美片在线播放| 在线观看亚洲专区| 91女神在线视频| av福利精品导航| 国产·精品毛片| 国产精品中文有码| 麻豆免费精品视频| 免费人成黄页网站在线一区二区| 亚洲一级电影视频| 亚洲自拍偷拍欧美| 一区二区三区免费网站| 亚洲另类在线一区| 亚洲欧美日韩一区二区 | 国产精品久久三区| 中文字幕一区二区在线观看| 中文字幕精品一区| 国产精品污污网站在线观看| 国产色91在线| 欧美极品少妇xxxxⅹ高跟鞋| 国产欧美一区二区精品性| 久久理论电影网| 日本一区二区三区四区在线视频| 久久久99久久| 国产精品久久久久久久蜜臀| 国产精品久久久久久久岛一牛影视 | 色综合久久久网| 色av一区二区| 欧美夫妻性生活| 日韩三级电影网址| 久久久久国产免费免费| 久久蜜桃一区二区| 国产精品三级视频| 亚洲免费高清视频在线| 亚洲成a人在线观看| 午夜精品福利一区二区三区av| 天天综合网天天综合色| 蜜臀av性久久久久蜜臀av麻豆| 蜜臀国产一区二区三区在线播放| 精品一区二区三区蜜桃| 国产精品综合二区| 色婷婷av一区二区三区大白胸| 欧美日韩中文精品| 日韩欧美国产一区在线观看| 久久久99精品免费观看不卡| 专区另类欧美日韩| 天堂资源在线中文精品| 韩国精品久久久| 一本一道波多野结衣一区二区 | 不卡av在线免费观看| 在线亚洲免费视频| 日韩女同互慰一区二区| 中文字幕亚洲在| 日本网站在线观看一区二区三区 | 亚洲一区二区三区小说| 久久精品国内一区二区三区| www.av精品| 欧美一区国产二区| 最新不卡av在线| 免费xxxx性欧美18vr| 成人永久aaa| 欧美一区二区三区免费观看视频| 中文字幕免费一区| 三级在线观看一区二区| 成人国产精品免费观看| 欧美一二三四在线| 亚洲激情欧美激情| 国产成人免费视频网站| 欧美高清一级片在线| 中文字幕一区在线观看| 蜜桃视频在线观看一区二区| 色综合天天性综合| 久久久综合视频| 日韩av一二三| 欧美性做爰猛烈叫床潮| 国产精品麻豆久久久| 久久爱www久久做| 欧美高清dvd| 亚洲综合999| 一本大道久久a久久综合| 久久九九99视频| 黄页网站大全一区二区| 制服视频三区第一页精品| 亚洲欧美日韩一区二区| 国产成人福利片| 久久亚洲私人国产精品va媚药| 亚洲电影在线免费观看| 色偷偷一区二区三区| 国产精品女上位| 国产二区国产一区在线观看| 精品美女一区二区| 人人超碰91尤物精品国产| 欧美这里有精品| 亚洲欧美另类久久久精品| 国产99久久久久久免费看农村| 欧美精品亚洲一区二区在线播放| 久久先锋资源网| 蜜桃久久久久久| 91精品国产品国语在线不卡| 亚洲精品国产一区二区精华液| 成人av高清在线| 日韩欧美www| 日本在线播放一区二区三区| 在线观看www91| 亚洲bdsm女犯bdsm网站| 91免费在线视频观看| 国产精品伦一区| 精品一区二区三区av| 精品日韩欧美一区二区| 日韩激情一二三区| 中文字幕不卡在线| 成人一区二区三区在线观看 | 日韩欧美国产综合一区| 奇米777欧美一区二区| 日韩欧美国产一区二区在线播放 | 一区二区三区四区高清精品免费观看 | 7777精品伊人久久久大香线蕉最新版| 一级精品视频在线观看宜春院| 成人不卡免费av| 亚洲日本韩国一区| www.一区二区| 亚洲人吸女人奶水| 欧美日韩在线免费视频| 香蕉成人伊视频在线观看| 日韩亚洲国产中文字幕欧美| 日产国产欧美视频一区精品| 精品国产乱码久久久久久夜甘婷婷 | 色婷婷激情久久| 日韩精品久久久久久| 日韩欧美aaaaaa| 久久99蜜桃精品| 日韩区在线观看| 久久不见久久见免费视频7 | 亚洲国产欧美在线| 欧美成人欧美edvon| 高清国产一区二区三区| 国产精品动漫网站|